꾸준한 스터디
article thumbnail
  • 상수를 정의하는 용도로 인터페이스를 사용하지 말 것!
    • 클래스 내부에서 사용할 상수는 내부 구현에 해당한다.
    • 내부 구현을 클래스의 API로 노출하는 행위가 된다.
    • 클라이언트에 혼란을 준다.
  • 상수를 정의하는 방법
    • 특정 클래스나 인터페이스
    • 열거형
    • 인스턴스화 할 수 없는 유틸리티 클래스

 

인터페이스에 상수를 정의하면
구현한 하위 클래스에서 필드명으로 나타낼 수 있다.

네임 스페이스 없이 편리하게 필드값을 사용하고자 인터페이스에 상수를 정의한다면 안티 패턴으로 권장하지 않는 코드이다. 인터페이스의 원래 용도를 오염시키기 때문. 인터페이스를 만드는 의도는 타입을 정의하기 위해서이다.

 

인터페이스는 공통 사용기술서이자 타입정의서이지 실질적으로 상수를 사용하는 곳은 class 에서 사용하니 class 내부에 정의하는 것이 맞다.

 

만약 여러군데에서 사용하는 상수라면 상속할 수 없는 유틸리티 클래스에 정의하는 것이 좋다.

숫자 리터럴에 사용한 _ 언더바는 자바 7부터 허용된 값에 아무런 영향없이 보기 편하게 해준다

 

클래스의 상수를 빈번히 사용할 경우 정적 임포트를 사용하여 클래스 이름을 생략할 수 있다.

 

 

  • 바이너리 호환성 : 뭔가를 바꾼 이후에도 에러 없이 기존 바이너리(클래스들)가 실행될 수 있는 상황. 인터페이스에서 상수를 선언했고 구현한 클래스에서 그 상수를 가져다 쓴다면? 추후 인터페이스에서 그 상수를 없앤다면 구현한 클래스에서 해당 상수를 찾을 수 없으니 코드 변경이 필요하고 다시 컴파일해야 시스템을 실행할 수 있다. 디폴트 메서드는 추가를 해도 구현한 클래스에서 별도 오버라이딩을 하지 않아도 되는데 이를 바이너리 호환성이라고 한다. 한마디로 클래스를 변경할 때, 그 클래스를 사용하는 클래스들에서 리컴파일 할 필요가 없어야된다.

 

 

https://inf.run/KQ24

 

이펙티브 자바 완벽 공략 2부 - 인프런 | 강의

자바 학습의 끝판왕 “이펙티브 자바”를 보다 쉽고 완벽하게 학습하세요. 이 강의를 수강하시면 여러분의 자바 프로그래밍 지식과 실력뿐 아니라 학습 능력 또한 향상시킬 수 있습니다., - 강

www.inflearn.com

 

profile

꾸준한 스터디

@StudyRecord

포스팅이 유익하셨다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!