인프런 커뮤니티 질문&답변

박재성님의 프로필 이미지
박재성

작성한 질문수

김영한의 실전 자바 - 중급 1편

문제와 풀이1

AuthGrade 문제2 - 인증 등급 열거형 조회

작성

·

175

0

=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
문제2에서 AuthGradeMain1 클래스를 만들어서 코드를 작성하는 과정에서 for문 안에서 바로 출력을 하는 코드를 작성하셨는데, EnumRefMain3_4에서

public static void main(String[] args) {
    int price = 10000;
    Grade[] grades = Grade.values();
    for (Grade grade : grades) {
        printDiscount(grade, price);
    }
}

private static void printDiscount(Grade grade, int price) {
    System.out.println(grade.name() + " 등급의 할인 금액 : " + grade.discount(price));
}

따로 print 메서드를 뽑아서 리팩토링 하셔서 제가 스스로 AuthGradeMain1 풀이할 때에도

public static void main(String[] args) {
        AuthGrade[] grades = AuthGrade.values();
        for (AuthGrade grade : grades) {
            printAuthGrade(grade);
        }
    }

    private static void printAuthGrade(AuthGrade authGrade) {
        System.out.println("grade = " + authGrade + ", level = " + authGrade.getLevel() + ", 설명 = " + authGrade.getDescription());
    }

이런 식으로 메서드를 뽑아서 풀었습니다. 결과는 결국 똑같이 나오겠지만 메서드를 뽑아서 print하는 코드와 for문에서 직접 print하는 코드 둘 중 어느 걸 사용하는 것이 좋은 건지 어떻게 알 수 있는 걸까요?

답변 1

1

안녕하세요. 박재성님, 공식 서포터즈 OMG입니다.

1줄짜리의 코드를 별도의 함수로 추출할 때, 저라면 다음과 같은 기준이 좋을 것 같습니다.

 

(1) 별도의 함수로 추출하여 메서드에 의미있는 이름을 부여함으로써 가독성이 좋아지는가?

(2) 재사용 가능성이 있는가?

 

예를 들어, 디버깅을 위한 단순 출력문과 같은 경우는 (1)의 기준에 따라 1줄로 처리해도 될 것 같습니다.

 

강의에서는 출력문에 별도의 의미있는 이름을 부여하여 코드의 가독성을 높인 의도일 것 같네요 😀

감사합니다.

박재성님의 프로필 이미지
박재성

작성한 질문수

질문하기