Effective Java 21. 인터페이스는 구현하는 쪽을 생각해 설계하라

Jung Ho Seo·2020년 7월 20일
0

EffectiveJava

목록 보기
3/35
post-thumbnail

Interface

java 8이전에는 기존 구현체를 깨트리지 않고는 인터페이스에 메서드를 추가할 방법이 없었다. 인터페이스에 메서드를 추가하면 보통은 컴파일 오류가 나는데, 추가된 메서드가 우연히 기존 구현체에 이미 존재할 가능성은 아주 낮기 때문이다. 자바 8에 와서는 디폴트 메서드라는 기능치 추가 되었지만, 그렇다고 위험이 완전히 사라진 것은 아니다.

디폴트 메서드를 선언하면, 그 인터페이스를 구현한 후 디폴트 메서드를 재정의 하지 않은 모든 클래스에서 디폴트 구현이 사용되게 된다.

디폴트 메서드는(컴파일에 성공하더라도) 기존 구현체에 런타임 오류를 일으킬 수 있다. 흔한 일은 아니지만, 나에게는 일어나지 않으리라는 보장도 없다. 자바 8은 컬렉션 인터페이스에 꽤 많은 디폴트 메서드를 추가 했고, 그 결과 기존에 짜여진 자바 코드가 영향을 받은 것으로 알려졌다.

디폴트 메서드는 인터페이스로부터 메서드를 제거하거나 기존 메서드의 시그니처를 수정하는 용도가 아님을 명심해야 한다. 이런 형태로 구현할 경우 반드시 기존 구현을 망가뜨리게 된다.

profile
책, 글, 개발

0개의 댓글