Рекомендуется всегда использовать @Override
, поскольку это может помочь вам упреждающе ловить некоторые в противном случае коварные ошибки. Это также повышает четкость кода. Например, посмотрите пример, приведенный в Effective Java , глава 6, пункт № 36:
// Can you spot the bug? - Page 176
package org.effectivejava.examples.chapter06.item36;
import java.util.HashSet;
import java.util.Set;
public 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 static void main(String[] args) {
Set<Bigram> s = new HashSet<Bigram>();
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(Object o)
, вместо этого реализовав equals(Bigram b)
, который будет не вызываться при выполнении действий, зависящих от equals()
; т.е. вставка экземпляров Bigram
в Map
. Таким образом, это приведет к запутанному, тонкому неправильному поведению, которое будет трудно отследить, тогда как если бы программист просто использовал @Override
, компилятор немедленно предупредил бы их о проблеме.