请问两个对象值相同(x.equals(y) == true),但却可有不同的hash code,这句话对不对? 为什么啊
4个回答
展开全部
虽然你是可以做到相等对象hashcode不同,但是会出问题的,比如说有对象A和B,AequalsB,你把A放进HashMap中作为key,但是你通过map.get(B)是取不出你存的对象的,然后AequalsB
所以javaAPI中Object的equals做了以下的说明,注意最后一句话:
指示某个其他对象是否与此对象“相等”。
equals 方法在非空对象引用上实现相等关系:
自反性:对于任何非空引用值 x,x.equals(x) 都应返回 true。
对称性:对于任何非空引用值 x 和 y,当且仅当 y.equals(x) 返回 true 时,x.equals(y) 才应返回 true。
传递性:对于任何非空引用值 x、y 和 z,如果 x.equals(y) 返回 true,并且 y.equals(z) 返回 true,那么 x.equals(z) 应返回 true。
一致性:对于任何非空引用值 x 和 y,多次调用 x.equals(y) 始终返回 true 或始终返回 false,前提是对象上 equals 比较中所用的信息没有被修改。
对于任何非空引用值 x,x.equals(null) 都应返回 false。
Object 类的 equals 方法实现对象上差别可能性最大的相等关系;即,对于任何非空引用值 x 和 y,当且仅当 x 和 y 引用同一个对象时,此方法才返回 true(x == y 具有值 true)。
注意:当此方法被重写时,通常有必要重写 hashCode 方法,以维护 hashCode 方法的常规协定,该协定声明相等对象必须具有相等的哈希码。
下面是API对hashCode的解释(注意隔开的那段)
public int hashCode()返回该对象的哈希码值。支持该方法是为哈希表提供一些优点,例如,java.util.Hashtable 提供的哈希表。
hashCode 的常规协定是:
在 Java 应用程序执行期间,在同一对象上多次调用 hashCode 方法时,必须一致地返回相同的整数,前提是对象上 equals 比较中所用的信息没有被修改。从某一应用程序的一次执行到同一应用程序的另一次执行,该整数无需保持一致。
如果根据 equals(Object) 方法,两个对象是相等的,那么在两个对象中的每个对象上调用 hashCode 方法都必须生成相同的整数结果。
以下情况不 是必需的:如果根据 equals(java.lang.Object) 方法,两个对象不相等,那么在两个对象中的任一对象上调用 hashCode 方法必定会生成不同的整数结果。但是,程序员应该知道,为不相等的对象生成不同整数结果可以提高哈希表的性能。
实际上,由 Object 类定义的 hashCode 方法确实会针对不同的对象返回不同的整数。(这一般是通过将该对象的内部地址转换成一个整数来实现的,但是 JavaTM 编程语言不需要这种实现技巧。)
比如下面的程序,你把hashCode方法注释掉结果是不一样的
import java.util.*;
class Student {
private int age;
public Student(int age) {
this.age = age;
}
public boolean equals(Object o) {
if(!(o instanceof Student))
return false;
Student stu = (Student)o;
if(stu.age == this.age) {
return true;
}
return false;
}
public int hashCode() {
return this.age * 37;
}
}
public class Test {
public static void main(String[] args) {
Map<Student,String> map = new HashMap<Student,String>();
Student s1 = new Student(12);
Student s2 = new Student(12);
map.put(s1,"TestCode");
System.out.println(map.get(s2));
}
}
所以javaAPI中Object的equals做了以下的说明,注意最后一句话:
指示某个其他对象是否与此对象“相等”。
equals 方法在非空对象引用上实现相等关系:
自反性:对于任何非空引用值 x,x.equals(x) 都应返回 true。
对称性:对于任何非空引用值 x 和 y,当且仅当 y.equals(x) 返回 true 时,x.equals(y) 才应返回 true。
传递性:对于任何非空引用值 x、y 和 z,如果 x.equals(y) 返回 true,并且 y.equals(z) 返回 true,那么 x.equals(z) 应返回 true。
一致性:对于任何非空引用值 x 和 y,多次调用 x.equals(y) 始终返回 true 或始终返回 false,前提是对象上 equals 比较中所用的信息没有被修改。
对于任何非空引用值 x,x.equals(null) 都应返回 false。
Object 类的 equals 方法实现对象上差别可能性最大的相等关系;即,对于任何非空引用值 x 和 y,当且仅当 x 和 y 引用同一个对象时,此方法才返回 true(x == y 具有值 true)。
注意:当此方法被重写时,通常有必要重写 hashCode 方法,以维护 hashCode 方法的常规协定,该协定声明相等对象必须具有相等的哈希码。
下面是API对hashCode的解释(注意隔开的那段)
public int hashCode()返回该对象的哈希码值。支持该方法是为哈希表提供一些优点,例如,java.util.Hashtable 提供的哈希表。
hashCode 的常规协定是:
在 Java 应用程序执行期间,在同一对象上多次调用 hashCode 方法时,必须一致地返回相同的整数,前提是对象上 equals 比较中所用的信息没有被修改。从某一应用程序的一次执行到同一应用程序的另一次执行,该整数无需保持一致。
如果根据 equals(Object) 方法,两个对象是相等的,那么在两个对象中的每个对象上调用 hashCode 方法都必须生成相同的整数结果。
以下情况不 是必需的:如果根据 equals(java.lang.Object) 方法,两个对象不相等,那么在两个对象中的任一对象上调用 hashCode 方法必定会生成不同的整数结果。但是,程序员应该知道,为不相等的对象生成不同整数结果可以提高哈希表的性能。
实际上,由 Object 类定义的 hashCode 方法确实会针对不同的对象返回不同的整数。(这一般是通过将该对象的内部地址转换成一个整数来实现的,但是 JavaTM 编程语言不需要这种实现技巧。)
比如下面的程序,你把hashCode方法注释掉结果是不一样的
import java.util.*;
class Student {
private int age;
public Student(int age) {
this.age = age;
}
public boolean equals(Object o) {
if(!(o instanceof Student))
return false;
Student stu = (Student)o;
if(stu.age == this.age) {
return true;
}
return false;
}
public int hashCode() {
return this.age * 37;
}
}
public class Test {
public static void main(String[] args) {
Map<Student,String> map = new HashMap<Student,String>();
Student s1 = new Student(12);
Student s2 = new Student(12);
map.put(s1,"TestCode");
System.out.println(map.get(s2));
}
}
展开全部
对,每个对象都有自己的hashcode码,这是唯一的,当两个对象用==比较时,比较他们的内存地址是否一致,如果一致,他们的hashcode一定相同。
而用equals比较时 ,许多类都重载该方法,单比较值而已,他们的内存地址可能不一致。
而用equals比较时 ,许多类都重载该方法,单比较值而已,他们的内存地址可能不一致。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
明显是对的,equals是可以override的.同楼上
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
对的 因为equals可以覆写的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询