सरल अंक के निम्न वर्ग के लिए एक समानता विधि जोड़ने पर विचार करें:कैसे जावा
public class Point {
private final int x;
private final int y;
public Point(int x, int y) {
this.x = x;
this.y = y;
}
public int getX() {
return x;
}
public int getY() {
return y;
}
// ...
}
// मेरी बराबरी की परिभाषा
public boolean equals(Point other) {
return (this.getX() == other.getX() && this.getY() == other.getY());
}
क्या इस विधि के साथ गलत क्या है? ,
import java.util.HashSet;
HashSet<Point> coll = new HashSet<Point>();
coll.add(p1);
System.out.println(coll.contains(p2)); // prints false
कैसे यह है कि coll p2 शामिल नहीं है हो सकता है, भले ही:
Point p1 = new Point(1, 2);
Point p2 = new Point(1, 2);
Point q = new Point(2, 3);
System.out.println(p1.equals(p2)); // prints true
System.out.println(p1.equals(q)); // prints false
हालांकि, मुसीबत एक बार आप एक संग्रह में अंक डालना आरंभ शुरू होता है: पहली नज़र में, यह ठीक से काम करने लगता है पी 1 इसमें जोड़ा गया था, और पी 1 और पी 2 बराबर वस्तुएं हैं?
अच्छी व्याख्या यहां: http://bytes.com/topic/java/insights/723476-overriding-equals-hashcode-methods इसे आंतरिक करें - यह जावा में सबसे मौलिक नियमों में से एक है और अक्सर साक्षात्कार प्रश्न है। –