[英]Why is equals() not called while adding to HashSet and hashCode matches?
[英]Why hashcode is called in this example?
有人可以解释为什么在下面的示例中调用hashCode吗?
import java.util.List;
public class JSSTest extends Object{
public static void main(String args[]){
JSSTest a = new JSSTest();
JSSTest b = new JSSTest();
List<JSSTest> list = new java.util.ArrayList<JSSTest>();
list.add(a);
list.add(b);
System.out.println(list.get(0));
System.out.println(list.get(1));
}
@Override
public boolean equals(Object obj){
System.out.println("equals");
return false;
}
@Override
public int hashCode(){
System.out.println("hashCode");
return super.hashCode();
}
}
结果:
hashCode 0
JSSTest@1bab50a
hashCode 0
JSSTest@c3c749
默认的toString()
实现调用hashCode
。 这与列表无关。
这是一个相当少的复制:
public class JSSTest {
public static void main(String args[]){
JSSTest test = new JSSTest();
// Just to show it's not part of creation...
System.out.println("After object creation");
test.toString();
}
@Override
public boolean equals(Object obj){
System.out.println("equals");
return false;
}
@Override
public int hashCode(){
System.out.println("hashCode");
return super.hashCode();
}
}
(您也可以覆盖toString()
以显示之前/超级调用/之后的详细信息。)
它记录在Object.toString()
中:
The toString method for class Object returns a string consisting of the name of the class of which the object is an instance, the at-sign character `@', and the unsigned hexadecimal representation of the hash code of the object. 换句话说,此方法返回一个等于以下值的字符串:
getClass().getName() + '@' + Integer.toHexString(hashCode())
System.out.println(list.get(0));
我相信它是所有对象都具有的 Object.toString() 方法的一部分,除非您在自己的 class 中覆盖 toString()。 试试看。
因为Object
中的toString()
实现调用它..
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
覆盖toString
,它不会被调用
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.