기본 콘텐츠로 건너뛰기

[외국포스트공유] 자바개발자가 Enum에 대해서 반드시 알아야할 18가지.



개발하시면서 Enum은 많이 쓰시나요?

저 같은 경우는 회사 다니는 동안에는 사실 Enum을 아주 가끔 쓸 뿐 거의 사용하지 않았었는데요.
회사 그만두고 하는 작업에서는 Enum을 꽤 자주 사용하고 있습니다.
생각보다 편한 부분도 많고 코드 가독성도 좋아지는 것 같고 이래저래 장점이 많은데, 이 부분은 다른 포스트에서 이야기하기로 하고요.

앞으로 몇 개의 포스트가 될지는 모르겠지만 한동안은 Enum에 대한 포스트가 자주 올라가게 될 것 같습니다.

오늘 소개해드릴 것은 그 첫 편으로 자바 개발자가 반드시 알아야 할 Enum의 18가지 포인트에 대한 Pramod Bablad의 DZone에 올라온 글을 간단히 정리하겠습니다. 대부분 아시는 내용일 테고, 혹시 Enum을 아직 쓰지 않거나 잘 모르시는 분들을 위한 내용이라고 생각하시고 봐 주시기 바랍니다.

아래 원문 링크 한번 눌러주세요. (바로 창 닫지 마시고 잠시 열어놓으시면 더 고맙겠네요)

원문 : https://dzone.com/articles/18-points-every-java-developer-should-know-about-e

1. 정해져 있는 것은 아니지만, Enum의 Constant 들은 대문자로 사용합니다.

2. Enum이 비록 클래스가 아니지만, 클래스와 같이 Field, Constructor, Method를 가질 수 있습니다.

3. Enum의 Constructor(생성자)는 private 으로 선언해야 합니다. 이것은 매우 당연하죠. Enum을 new 로 생성하는 것이 가능하면 안되겠지요?

4. Enum Constant(열거형 상수)는 전체 실행에서 단 한 번만 생성됩니다. 모든 Enum Constant는 그중 하나가 코드에서 사용될 때 생성되고, 각 Enum 상수가 생성될 때 해당 Constructor가 호출됩니다.

5. Enum Constant는 Field, Constructor, Method보다 앞에서 정의되어야 합니다.

6. 모든 Enum은 java.lang.Enum을 상속합니다. 자바에서는 다중 상속이 지원되지 않기 때문에 당연하게도 Enum은 다른 클래스를 상속할 수 없습니다.

7. 상속은 안 되지만 interface는 구현이 되겠지요? (implement)

8. Enum Constant는 Constant Specific Body라고 불리는 자신만의 Body를 가질 수 있습니다. 이 Body 부분에 Field나 Method 를 정의할 수 있지만, 이 들은 해당 Body 내에서만 사용할 수 있습니다.

9. Enum은 자동으로 final로 선언됩니다. 따라서 다른 Enum에서 상속할 수 없어요.

10. 각각의 Enum type은 별개의 파일로 작성되어야 하고, 컴파일한 후에 .class 파일이 생성됩니다.

11. Enum type은 인스턴스 초기화 블록(Instance initialization block)뿐 아니라 정적 초기화 블록(Static initialization block)을 원하는 만큼 가질 수 있습니다. (https://stackoverflow.com/questions/11419519/enums-static-and-instance-blocks. 이 질문을 참고하시면 앞의 4번을 포함해서 좀 더 이해가 쉽겠네요)

12. 모든 Enum Type은 Comparable과 Serializable을 구현하고 있기 때문에 자동으로 모든 Enum Type은 비교 가능하고 직렬화 가능합니다.

13. Enum Constant(열거형 상수들)은 == 연산자로 비교할 수 있습니다. (하지만 저는 그냥 equals()를 사용합니다)

14. 어떤 Enum type의 constant도 values() 메소드로 조회할 수 있습니다. values() 메소드는 enum costant 들의 배열을 반환합니다.

15. Enum은 컴파일하는 동안 type-safety를 제공합니다. 즉, 정의되지 않은 enum constant를 사용한 경우 컴파일 중 오류가 발생합니다.

16. Enum은 클래스 밖 또는 안에서 정의할 수 있지만, method나 block 안에서는 정의할 수 없습니다.

17. ordinal() 메소드는 Enum type 안에서의 Constant의 순서를 반환하는 데 사용됩니다.  (그래서 정의된 순서가 달라지면 ordinal() 의 값이 변경됩니다. DB에 Ordinal을 그냥 사용하는 경우에는 조심해야하죠)

18. Enum은 주로 전체 실행에 대해서 일정하게 유지되는 제한된 옵션의 집합이나 컴파일 동안 가능한 모든 옵션을 알고 싶은 경우에 사용됩니다. 예를 들어 메뉴의 선택 값들이거나 콤보박스의 옵션들이 있습니다. (그러나 실제로는 메뉴나 콤보박스의 옵션들에 Enum 을 넣는 경우는 많지 않더군요..)

뭐 거의 직역에 가깝게 정리가 되어버렸네요.

원본 글을 읽어주셔야 저작자들이 도움이 됩니다. (페이지 조회수가 늘어나니까요)
주로 외국 포스트를 공유하는 글들을 많이 올립니다만, 매번 원 저작자들에게 굉장히 죄송한 마음을 가지게 되네요.



댓글

이 블로그의 인기 게시물

경력 개발자의 자기소개서에 대해서...

갑자기 뜬금없이 이런 글을 쓰다니 무슨 생각이야? 라고 생각하시는 분들이 있을지도 모르겠네요. 뜬금없음에 대한 변명은 잠시 접어두고 일단 오늘 쓰려고 하는 글을 시작해볼까 합니다. 개발자로 대충 16년을 그럭저럭 보내왔습니다. 시대적 상황으로 5년 차쯤에 대리로 처음 팀장을 시작했으니, 일반 개발자로 산 시간보다는 어쨌건 프로젝트 또는 팀의 리더로 산 시간이 더 많았던 것 같습니다. 그 기간 동안 남들보다 좀 심하게 회사를 많이 옮겨 다니다 보니 꽤 많은 면접을 볼 수 있는 경험이 있었고, 또 옮긴 회사가 대부분 팀을 리빌딩하는 곳이었다 보니 꽤 많은 채용절차에 관여할 기회가 있어서 어린 나이부터 비교적 많은 이력서를 검토했고 면접관으로도 여러 사람을 만날 수 있었습니다. 처음 면접을 보러 다니던 시절의 제 이력서의 자기소개서는 항상 "19XX년 봄 XX업계에 종사하시던 아버님과 집안일에 헌신적인 어머니의 유복한 가정에 1남 1녀의 막내로..." 로 시작되었습니다 (이 문장에 향수를 느끼시는 분들 많으실 거예요. ^^). 경력이 5년이 넘은 어느 날 도대체 이 문장을 왜 써야 하느냐는 의문이 생겨서 조금 바꾸긴 했습니다만, 그 뒤로도 꽤 오랜 세월을 이런 자기소개서가 항상 제 이력서에 붙어있었죠. 요즘 누가 저런 식으로 자기소개서를 써? 라고 생각하시는 분들 많으실 거로 생각해요. (대신 요즘은 대학 시절의 봉사활동이나 해외연수 이력이... 뭐 어차피 그놈이 그놈입니다.) 저런 자기소개서를 써야 한다는 것이 어디서 어떻게 시작된 것인지는 몰라도 회사를 그만두기 전인 2년 전까지도 약간의 표현은 다를지 모르지만 비슷한 문장으로 시작하는 자기소개서를 이력서에 첨부해서 보내는 지원자들을 볼 수 있었습니다. 이제 제가 뜬금없는 이런 글을 쓰게 된 이유를 밝히고 계속 진행해야겠네요. 블로그에 올릴 글을 준비하는 일이 생각보다 힘들어요. 블로그에 올리려고 준비한 주제에 맞는 소스를 작업하고 거기에 글을 입히다 보면 가끔 ...

Springframework 5에서 바뀌는 것들에 대한 간단 정리 및 생각

Spring framework 5 에 대해 많은 분이 기대와 두려움을 가지고 계시지 않을까 생각합니다. 특히 기대를 하고 계신 분들은 Reactive Programming 지원을 기대하고 계시지 않은가 생각이 드는데요. 7월 초에 John Thompson 이란 분이 D-Zone에 아주 깔끔하고 멋지게 정리를 잘해서 글을 쓰셨더라구요. 해당 글은  https://dzone.com/articles/whats-new-in-spring-framework-5 에서 확인을 하실 수 있습니다. 혹시 Spring framework 5에서 달라지는 내용의 좀 더 자세한 내용이 필요하신 분들은 Spring framework github의 wiki 를 참고하시면 됩니다. 본 포스트는 언제나 그렇듯이 윗글에 대한 번역이 아닙니다. 그저 윗글을 다시 정리하면서 제 생각을 한번 정리해 놓은 포스트입니다. Spring framework 5는 현재 5.0.0.RC2(2017.07.23일 기준)까지 릴리즈된 상황입니다. Spring framework 5에서 크게 변화하는 내용을 John Thompson은 8가지로 깔끔하게 정리해주고 있습니다. 1. JDK 지원 버전의 업데이트 5버전은 원래 JDK 9 버전의 지원을 위해서 시작됐던 프로젝트로 알고 있는데 맞는지는 모르겠네요. JDK 9의 Release가 늦어져서 Spring framework 5가 먼저 Release 될 것으로 보이지만, JDK 9가 Release가 되면 언제건 적용할 수 있다고 합니다. 좀 아쉬운 부분은 JDK의 최소 버전은 JDK 8이라는 부분이 아닐까 싶네요. 이 때문에 Spring framework 5에 무관심한 분들도 많으실 거라고 생각합니다. 지금 진행하는 프로젝트는 JDK 8을 기반으로 합니다만, 최근까지 다니던 회사의 경우는 JDK 7까지가 업그레이드 한계였던 회사였습니다. 아마도 JDK 업그레이드를 쉽게 못 하시는 회사들이 많으니 "나랑은 관계없는 얘기군...

자바에서 파일 타입을 확인하는 방법들... 그리고 Apache Tika...

뭐 역시나 내가 직접 조사한 것은 아니고 Java Code Geeks 에서 본 내용에 대한 정리이다. 자세한 사항은 [원문보기]  를 클릭해서 확인하면 된다. 원문에서는 코드와 스크린샷을 포함한 예제를 확인할 수 있으니 내용을 보시고자 하시는 분들은 꼭 원문을 참고하시길... 내가 쓰는 포스트가 대부분 그렇지만, 이 글도 그저 내용을 정리해서 내가 나중에 확인하기 위해 쓰는 글일 뿐... 1. Files.probeContentType(Path)를 이용하는 방법 [JDK 7] 이 방법은 파일 확장자를 이용해서 판단하는 것으로 보인다. 즉, gif 파일을 png라고 확장자를 주면 png 로 인식한다는 것. 또 확장자가 없는 파일의 경우는 null 을 리턴한다. 2. MimetypesFileTypeMap.getContentType(String) 을 이용하는 방법 [JDK 6] 이 방법은 클래스 명에서 유추가 가능한 것 처럼 Mime type 을 이용한다. 앞서의 경우와 같이 gif 파일을 png 라고 하거나 pdf 파일을 txt 로 하거나 하면 확장자로 판단을 한다. 1번 경우와 다른 점을 이야기하자면 기본적으로 텍스트나 이미지 확장자가 아닌 경우에는 xml 파일을 포함해서 application/octet-stream을 반환한다. 또한 확장자가 없는 파일의 경우도 application/octet-stream을 반환한다. 3. URLConnection.getContentType() 이 방법 역시 확장자에 의한 판단. 대신 null 대신 content/unknown을 반환 4. URLConnection.guessContentTypeFromName(String) 역시 확장자. 3번과 다른 것은 null을 반환. 5. URLConnection.guessContentTypeFromStream(InputStream) 예제에서는 전부 null 을 반환. 저자의 설명에 따르면 여기서 매개변수로 주어진 InputStream은 ma...