최근에 회사 코드에서 int 열거형을 활용하는 방법이 많다는 걸 알았고, 열거형을 활용하는 방법도 몇 가지 봤습니다. 저는 이에 대해 매우 궁금해서 연구를 하였고, 왜 enum을 사용해야 하는지 정리하기 위해 이 글을 썼습니다.
Java가 열거형을 사용하는 이유는 무엇인가요?
이제 예약 주문과 비예약 주문이라는 두 가지 주문 유형이 있다고 가정해 보겠습니다.
요구 사항 1: submitOrder 메소드는 다양한 주문 유형에 따라 다양한 처리를 수행합니다.
요구 사항 2: 주문 유형을 OrderResult 개체로 설정합니다.
다음은 두 가지 열거 방법을 사용하여 구현됩니다.
int 열거형
class IntEnumExample{ private static final PRE_ORDER = 1; private static final NOT_PRE_ORDER = 2; public void submitOrder(int orderType, OrderResult orderResult){ orderResult.setType(orderType); if(orderType == PRE_ORDER){ do something to process preOrder }else if(orderType == NOT_PRE_ORDER){ do something to process other order } } public static void main(String [] args){ IntEnumExample example = new IntEnumExample(); //passing wrong type to the method, however, no compile error and runtime exception here, the bug is hard to be discerned. example.submitOrder(3, orderResult); } }
위의 예에서 볼 수 있듯이 int 열거형 사용에는 몇 가지 단점이 있습니다.
1.int 열거형은 유형 검사를 수행하지 않으며 모든 int를 submitOrder 메소드에 전달할 수 있습니다. 위의 값
2. 문서나 소스 코드가 없으면 submitOrder에 전달된 값의 의미를 알 수 없습니다.
그뿐만 아니라, 이전 프로젝트에서 소나 스캐닝 코드를 수정했을 때 발견한 문제처럼, 위 예시처럼 int 열거형을 사용할 때 int 값을 static final로 정의하지 않는 분들이 많았습니다. 변수를 final로 정의하는 것을 잊어버린 경우 int 열거형의 값이 수정될 수 있습니다. 변수를 static으로 정의하는 것을 잊은 경우 해당 변수를 사용할 때 int 값이 초기화되지 않을 수 있습니다.
간단히 말하면 버그가 발생하게 됩니다.
Enum을 사용하여 동일한 작업을 수행하는 방법을 살펴보겠습니다.
class IntEnumExample{ private enum ORDER_TYPE { NOT_PRE_ORDER(1),PRE_ORDER(2); private final int value; private ORDER_TYPE(int value){ this.value = value; } } public void submitOrder(ORDER_TYPE orderType, OrderResult orderResult){ orderResult.setType(orderType); if(orderType == ORDER_TYPE.PRE_ORDER){ do something to process preOrder }else if(orderType == ORDER_TYPE.NOT_PRE_ORDER){ do something to process other order } } public static void main(String [] args){ IntEnumExample example = new IntEnumExample(); //compiler will complain error here, if argument is not the type in the enum. example.submitOrder(ORDER_TYPE.PRE_ORDER, orderResult); } }
위 코드에서 볼 수 있듯이 enum은 이전 예제의 문제를 우아하게 해결합니다.
1. 컴파일러는 enum에 대한 유형 검사를 수행합니다. 유형이 일치하지 않으면 컴파일러가 직접 오류를 보고합니다.
2. int 열거형에서 int 값을 직접 전달하는 방식과 비교하면 enum 형 객체의 방식이 전달되어 코드의 가독성이 높아지고 전달된 열거형이 한눈에 알 수 있습니다.
3. 열거형 유형 자체의 객체는 정적 최종입니다.
중요 사항:
때때로 각 열거형에 int 값을 할당하려는 경우 위 예제의 열거형 정의를 사용해야 한다는 점도 언급할 가치가 있습니다.
private enum ORDER_TYPE { NOT_PRE_ORDER(1),PRE_ORDER(2); private final int value; private ORDER_TYPE(int value){ this.value = value; } }
enum은 본질적으로 클래스이므로 ORDER_TYPE(int value) 메서드는 이 열거형 유형의 생성자입니다. 따라서 각 열거형 유형은 초기화 중에 PRE_ORDER(2) 와 같이 응답 값을 생성자에 전달해야 합니다.
이 경우 열거형에 해당하는 int 값을 얻고 싶다면 ORDER_TYPE.PRE_ORDER.value를 통해 얻을 수 있습니다.
enum 유형과 int 유형 간의 연관성을 직접 구현하기 위해 enum의 ordinal() 메서드를 직접 사용하는 사람들도 있기 때문에 enum 사용법은 별도로 언급됩니다. ordinal() 메소드는 정의되었을 때 열거형 유형의 서수를 반환합니다. 예를 들어 ORDER_TYPE.PRE_ORDER.value.ordinal()은 0 값을 반환합니다. 따라서 열거형에 해당하는 int 값을 얻는 것도 ORDER_TYPE.PRE_ORDER.value.ordinal()+1을 통해서도 얻을 수 있을 것으로 보인다.
서수() 메소드를 사용하지 마세요! ordinal() 메소드를 사용하지 마세요! ordinal() 메소드를 사용하지 마세요! 중요한 말을 세 번 말하라, 왜?
서수는 매우 신뢰할 수 없으며 변경될 수 있습니다. 어느 날 ORDER_TYPE의 정의가 변경되어 여러 유형을 추가해야 하거나 NOT_PRE_ORDER 및 PRE_ORDER 정의의 순서가 실수로 다음과 같이 변경되었다고 가정해 보세요. 심각한 버그는 찾기 어렵습니다. 컴파일이나 런타임 중에 오류가 발생하지 않습니다.
그러므로 ordianl() 메서드에 의존하지 마세요.
관련 학습 권장사항:Java 기본 튜토리얼
위 내용은 Java가 열거형을 사용하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!