【发布时间】:2017-03-18 22:59:32
【问题描述】:
我正在重读 Stuart Reges 的 Building Java Programs 并注意到一些我不太理解的东西。它与在任何新类中重载 equals() 方法有关。假设我们这样定义一个类:
public Point{
private int x;
private int y;
public Point(int x, int y){
this.x = x;
this.y = y;
}
public getX(){
return this.x;
}
public getY(){
return this.y;
}
}
这本书建议,任何时候我们定义一个新类,我们为一个新类定义的 equals() 方法都应该这样写:
public boolean equals(Object o) {
if (o instanceof Point) {
Point other = (Point) o;
return x == other.x && y == other.y;
} else {
return false;
}
}
为什么 equals 方法应该接受泛型类型“Object”而不是“Point”类型的对象?这本书说,如果 equals 方法头与泛型 Object 类的 equals 方法头不匹配,它将不会被重载(我知道它不会被重载,否则)。然而,这有点不直观,因为它们实际上可能相等的唯一时间是它们是否属于同一类型......
当我将一个 String 对象作为参数传递给我的 equals() 方法时,该方法接受 Point 类型的参数,而不是 String,它正确返回 false。每当我们传递不同的类型时,通用的 equals() 方法(比较内存地址)不适合吗?
【问题讨论】:
-
考虑这样一种情况,您可能有一个存储文本表示的类,类似于字符串(但具有一些附加功能)。是否存在您希望 equals() 和 hashCode() 语义导致它与具有相同内容的 String 对象进行比较的情况?
标签: java inheritance overloading