@Override 애너테이션을 일관되게 사용하면 여러 가지 악명 높은 버그들을 예방해준다.
class Bigram {
private final char first;
private final char second;
public Bigram(char first, char second) {
this.first = first;
this.second = second;
}
public boolean equals(Bigram b) {
return b.first == first && b.second == second;
}
public int hashCode() {
return 31 * first + second;
}
}
public class Item40 {
public static void main(String[] args) {
Set<Bigram> s = new HashSet<>();
for (int i = 0; i < 10; i++)
for (char ch = 'a'; ch <= 'z'; ch++)
s.add(new Bigram(ch, ch));
System.out.println(s.size());
}
}
따라서 equals 부분을 다음과 같이 수정해야 한다.
@Override
public boolean equals(Object o) {
if(!(o instanceof Bigram)) return false;
Bigram b = (Bigram) o;
return b.first == first && b.second == second;
}
reference
https://programmers.co.kr/learn/courses/5/lessons/241
재정의한 모든 메서드에 @Override를 의식적으로 달면 실수했을 때 컴파일러가 바로 알려줄 것이다.
예외는 한 가지뿐이다. 구체 클래스에서 상위 클래스의 추상 메서드를 재정의한 경우엔 @Override를 달지 않아도 된다.
하지만, 단다고 해서 해로울 것이 없다.