class Point{
int x, y, l;
Point(int x, int y, int l){
this.x =x;
this.y =y;
this.l=l;
}
@Override
public int hashCode() {
return y;
}
@Override
public boolean equals(final Object obj) {
if(this == obj) return true;
if(!(obj instanceof Point)) return false;
Point p = (Point) obj;
return this.x == p.x && this.y == p.y;
}
}
TreeMap<Point,Integer> sortedMap = new TreeMap<>((p1, p2)-> p1.l-p2.l);
sortedMap.put(new Point(4,5,0),0);
sortedMap.put(new Point(5,5,0),6);
System.out.println(sortedMap.size()); -> Output: 1
System.out.println((new Point(4,5,0)).equals(new Point(5,5,0))); -> Output -> False.
我重載了哈希碼,equals方法在類中。我認爲put方法應該使用equals方法來確定相同的對象是否退出。但它沒有按預期工作。TreeMap投入不按預期工作
我不確定爲什麼我的hashMap大小爲1.請讓我知道,如果我理解hashmap工作錯誤。幫我找出這段代碼中的錯誤?
爲什麼你的平等檢查'p1.l - p2.l'? –
爲什麼當它不是一個集合,而是一個地圖時,調用變量'sortedSet'? –
@MuratK:這不是一個平等檢查 - 這是一個排序。 –