作者:初升的太阳1866 | 来源:互联网 | 2023-05-22 19:48
假设我有一个带有颜色和模型字段的汽车.我需要将汽车存放在一个集合中,我将不会重复(没有2辆相同的汽车).在下面的示例中,我使用的是HashMap.
根据Java文档,如果我们有2个Car对象car1和car2这样car1.equals(car2) == true
,那么它也必须持有它car1.hashCode() == car2.hashCode()
.因此,在这个例子中,如果我想只是它们的颜色比较汽车,那么我会只用色域的equals()
和hashCode()
,正如我在我的代码做了,而且它完美的罚款.
public class Car {
String color;
String model;
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((color == null) ? 0 : color.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Car other = (Car) obj;
if (color == null) {
if (other.color != null)
return false;
} else if (!color.equals(other.color))
return false;
return true;
}
public Car(String color, String model) {
super();
this.color = color;
this.model = model;
}
@Override
public String toString() {
return color + "\t" + model;
}
public static void main(String[] args) {
Map cars = new HashMap();
Car a = new Car("red", "audi");
Car b = new Car("red", "bmw");
Car c = new Car("blue", "audi");
cars.put(a, a);
cars.put(b, b);
cars.put(c, c);
for(Car car : cars.keySet()) {
System.out.println(cars.get(car));
}
}
}
输出是:
红宝马
蓝色奥迪
正如所料.
到目前为止这么好.现在,我正在尝试比较2辆汽车的其他方法.我提供了测量2辆车之间相似性的功能.为了论证,我想有一个方法double similarity(Car car1, Car car2)
在区间[0,1]中返回一个double值.如果它们的相似函数返回大于0.5的值,我认为2辆汽车是相同的.然后,我重写equals方法:
@Override
public boolean equals(Object obj) {
Car other = (Car) obj;
return similarity(this, other) > 0.5;
}
现在,我不知道如何覆盖hashCode()以确保始终保持hashCode - equals合约,例如2个相等的对象始终具有相等的hashCodes.
我一直在考虑使用TreeMap而不是HashMap,只是为了避免覆盖hashCode,因为我不知道如何正确地执行它.但是,我不需要任何排序,所以我发现在这个问题中使用TreeMap是不合适的,而且我认为在复杂性方面它会更昂贵.
如果你可以建议我,那将是非常有帮助的:一种覆盖hashCode
或替代不同结构的方法,这种结构更适合我的问题.
先感谢您!