본문은 Effective Java를 읽고 간단하게 정리한 글입니다. 필요에 따라 생략/수정된 부분이 있을 수 있으며, 내용이 추후 변경될 수 있습니다.
선결론
- 기존 인터페이스에 디폴트 메서드로 새 메서드를 추가하는 일은 꼭 필요한 경우가 아니면 피해야 한다
- 반면, 새로운 인터페이스를 만드는 경우엔 유용하다
인터페이스 설계 및 테스트의 중요성
- 자바 8부터 추가된 디폴트 메서드로 인해 기존 인터페이스에 메서드를 추가하는 것이 가능해졌다
- 디폴트 메서드는 컴파일에 성공하더라도 기존 구현체에 런타임 오류를 일으킬 수 있다
- 디폴트 메서드는 인터페이스로부터 메서드를 제거하거나 기존 메서드의 시그니처를 수정하는 용도가 아니다
- 이런 형태로 인터페이스를 변경하면 반드시 기존 클라이언트를 망가뜨리게 된다
- 따라서 필자는 설계 및 테스트의 중요성을 강조하고 있다
- 릴리스 후에도 결함을 수정하는 것은 가능하지만, 그 파급효과가 크기 때문에 설계와 테스트에 집중하여 릴리스 전에 결함을 찾아내야 한다
'책 > Effective Java' 카테고리의 다른 글
[이펙티브 자바] 아이템 23: 태그 달린 클래스보다는 클래스 계층구조를 활용하라 (0) | 2022.05.11 |
---|---|
[이펙티브 자바] 아이템 22: 인터페이스는 타입을 정의하는 용도로만 사용하라 (0) | 2022.05.11 |
[이펙티브 자바] 아이템 20: 추상 클래스보다는 인터페이스를 우선하라 (0) | 2022.05.09 |
[이펙티브 자바] 아이템 19: 상속을 고려해 설계하고 문서화하라. 그러지 않았다면 상속을 금지하라 (0) | 2022.05.05 |
[이펙티브 자바] 아이템 18: 상속보다는 컴포지션을 사용하라 (0) | 2022.05.05 |