Вы пробовали переопределить суперкласс равными ... и затем автоматически сгенерировать реализацию переопределения подкласса ...
Я уверен, что это будет иначе.он будет вызывать super.equals ()
в текущей автоматически сгенерированной реализации, он только проверяет значения в дочернем классе.
Рассмотрим сценарий ниже, и вы поймете, почему предупреждение.
abstract Class A{
private int a;
public void setA(int a){
this.a=a;
}
}
Class B extends A{
private int x;
public void setX(int x){
this.x=x;
}
@Override
public boolean equals(Object obj) { // This does not call Super.equals
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
B other = (B) obj;
if (x != other.x)
return false;
return true;
}
}
и в основном методе попробуйте
B b1= new B();
b1.setA(10);
b1.setX(20);
B b2= new B();
b2.setA(20);
b2.setX(20);
if(b1.equals(b2)){
System.out.println("Warning was Right");
}