equals和hashcode总结:
equals方法没有重写的话,用于判断对象的内存地址引用是否是用一个地址。重写之后一般用来比较对象的内容是否相等(比如student对象,里面有姓名和年龄,我们重写equals方法来判断只要姓名和年龄相同就认为是用一个学生)。
hashcode是jdk根据对象的地址或者字符串或者数字算出来的int类型的数值,当然你也可以重写它,hashcode方法只有在集合中用到。
对象放入集合中时,先判断hashcode是否相等,再判断equals是否相等,都相等就算是同一个对象,list则可以放入,set因为不允许重复所以不会放入。
例如:
public class student { private int age; private string name; public student(int age ,string name){ this.age = age; this.name = name; } public int getage() { return age; } public void setage(int age) { this.age = age; } public string getname() { return name; } public void setname(string name) { this.name = name; } //重写equals方法,判断姓名和年龄相同就是相等的 public boolean equals(object o){ if(o == null){ return false; } if(this.getclass() != o.getclass()){ return false; } student student = (student)o; if(name == null){ return false; } if(age==student.getage()&&name.equals(student.getname())){ return true; } return false; } public static void main(string[] args) { student studentone = new student(1,"yjc"); student studenttwo = new student(1,new string("yjc")); system.out.println(studentone.equals(studenttwo)); system.out.println("1: "+studentone.getname().hashcode()); system.out.println("2: "+studenttwo.getname().hashcode()); } //输出结果:true 1: 119666 2: 119666}
以上可以看出,两个string都叫"yjc",无论是直接"yjc"还是new string("yjc"),他们的hashcode都相同。所以在重写hashcode方法时可以运用这一点。
比如你希望如果姓名和年龄相同,不仅equals相同,他们的hashcode也要相同,可以这样重写hashcode:
public int hashcode(){ final int prime = 31; int result = 1; result = prime*result + age; result = prime*result + (name == null? 0 : name.hashcode()); return result;//直接写age+(name == null? 0 : name.hashcode())也行就是感觉太简单了0.0}
这样一来两个姓名和年龄相同的student对象就是同一个对象了,放入set中会被认为是同一个,无论放几个这样的对象,set.size()都是等于1。
同样,hashmap因为key也是唯一的,hashmap对象是根据其key的hashcode来定位存储位置,并使用equals(key)获取对应的value,所以在put时判断key是否重复用到了hashcode和equals,若重复了则会覆盖。
以上就是equals和hashcode的详细内容。