일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
Tags
- db
- Greedy
- 우선순위큐
- join
- select
- IntelliJ
- BFS
- 그리디알고리즘
- 정렬
- 피보나치
- 백준
- 이펙티브자바
- mybatis
- 다이나믹프로그래밍
- DP
- 알고리즘
- mariaDB
- DFS
- 코테
- Database
- java
- Spring
- 깊이우선탐색
- 너비우선탐색
- 프로그래머스
- SQL
- 탐욕법
- Effective Java
- 데이터베이스
- springboot
Archives
- Today
- Total
땀두 블로그
[도서] Effective Java - Item 21. 인터페이스는 구현하는 쪽을 생각해 설계하라 본문
이펙티브 자바 3판을 읽으면서 내용을 정리하는 포스트입니다. 혹시 틀린 부분이나 잘 못 설명한 부분이 있으면 댓글로 남겨주시면 수정하도록 하겠습니다.
Item 21. 인터페이스는 구현하는 쪽을 생각해 설계하라
자바 8 버전 이전에는 인터페이스에 기존 구현부를 깨지 않고는 메소드를 추가할 수 없었다. 8버전 부터는 디폴트 메소드를 사용하여 이를 해결하였지만 이것도 완벽하지는 않다.
default boolean removeIf(Predicate<? super E> filter) {
Objects.requireNonNull(filter);
boolean removed = false;
final Iterator<E> each = iterator();
while (each.hasNext()) {
if (filter.test(each.next())) {
each.remove();
removed = true;
}
}
return removed;
}
예시로 나와있는 removeIf 메소드는 boolean 함수가 true를 반환하는 모든 원소를 제거한다.
Collection의 removeIf는 현재 범용적으로 사용을 하고 있지만, 아직까지 모든 Collection 구현체와 잘 어울지 않는다. SynchronizedCollection
의 경우 removeIf를 사용하게 되면 ConcurrentModificationException
을 발생시키거나, 다른 결과를 보내준다.
자바에서는 이러한 문제를 예방하기 위해 구현한 인터페이스의 디폴트 메소드를 재정의하고, 다른 메소드에서는 디폴트 메소드 호출 전 필요한 작업을 수행하도록 했다. 하지만 자바 플랫폼에 속하지 않은 것들은 수정될 기회가 없다.
또한 디폴트 메소드는 흔한일은 아니지만 기존 구현체에 런타임 오류를 발생시키는 경우도 있다.
따라서 우리는 디폴트 메소드라는 좋은 도구가 있더라도 인터페이스 설계를 할 때 주의를 기울여야 한다. 또한 새로운 인터페이스라면 릴리스 전에 반드시 테스트를 거쳐야 한다.
'도서' 카테고리의 다른 글
[도서] Effective Java - Item 23. 태그 달린 클래스보다는 클래스 계층구조를 활용하라 (0) | 2022.05.11 |
---|---|
[도서] Effective Java - Item 22. 인터페이스틑 타입을 정의하는 용도로만 사용하라 (0) | 2022.05.11 |
[도서] Effective Java - Item20. 추상 클래스보다는 인터페이스를 우선하라 (0) | 2022.05.11 |
[도서] Effective Java - Item 19. 상속을 고려해 설계하고 문서화하라. 그러지 않았다면 상속을 금지하라 (0) | 2022.05.11 |
[도서] Effective Java - Item 18. 상속보다는 컴포지션을 사용하라 (0) | 2022.05.11 |
Comments