아이템 35. ordinal 메서드 대신 인스턴스 필드를 사용하라

문법식·2022년 8월 23일
0

Effective Java 3/E

목록 보기
35/52

대부분의 열거 타입 상수는 자연스럽게 하나의 정숫값에 대응된다. 그리고 모든 열거 타입은 해당 상수가 그 열거 타입에서 몇 번째 위치인지를 반환하는 ordinal이라는 메서드를 제공한다. 이런 이유로 열거 타입 상수와 연결된 정숫값이 필요하면 ordinal 메서드를 이용하고 싶어질 수 있다. 다음 코드는 합주단의 종류를 연주자가 1명인 솔로부터 10명인 디텍트까지 정의한 열거타입이다.

pulbic enum Ensemble{
	SOLE, DUET, TRIO, QUARTET, QUINTET, SEXTET, SEPTET, OCTET, NONET, DECTET;
    
    public int numberOfMusicians(){
    	return ordinal()+1;
	}
}

동작은 하지만 유지보수하기가 끔찍한 코드이다. 상수 선언 순서를 바꾸는 순간 numberOfMusicians가 오작동하며, 이미 사용 중인 정수와 값이 같은 상수는 추가할 방법이 없다. 또한 값을 중간에 비워둘 수 없다.
해결책은 간단하다. 열거 타입 상수에 연결된 정숫값은 ordinal 메서드로 얻지 말고, 인스턴스 필드에 저장하자.

public enum Ensemble {
    SOLO(1), DUET(2), TRIO(3), QUARTET(4), QUINTET(5),
    SEXTET(6), SEPTET(7), OCTET(8), DOUBLE_QUARTET(8),
    NONET(9), DECTET(10), TRIPLE_QUARTET(12);

    private final int numberOfMusicians;
    Ensemble(int size) { this.numberOfMusicians = size; }
    public int numberOfMusicians() { return numberOfMusicians; }
}

EnumAPI 문서를 보면 ordinal에 대해 "대부분 프로그래머는 이 메서드를 쓸 일이 없다. 이 메서드는 EnumSetEnumMap 같이 열거 타입 기반의 범용 자료구조에 쓸 목적으로 설계되었다."라고 쓰여 있다. 따라서 이런 용도가 아니면 ordinal 메서드는 절대 사용하지 말자.

profile
백엔드

0개의 댓글