1.hashCode()方法和equals()方法的区别
1.1 hashCode()和equals()都是Object类中的方法
如果类中不重写此方法
hashCode():属于本地方法,返回的是对象的地址值
equals():用来比较两个对象的地址值是否相等
如果类中重写此方法
hashCode():返回的是根据对象的成员变量,计算出的一个整数
equals():比较的是两个对象中成员信息是否相等
规范
1.2 hashCode和equals返回值应该是稳定的,不应有随机性
1.3两对象==返回true,则这两个对象的equals也应该返回true
1.4两对象equals则两个对象的hashCode应该相等
1.5 类中重写hashCode()和equals()比较两个对象是否相等
两个对象通过equals()比较的是相等的,那么hashCode()肯定是相等,也就是equals()是绝对可靠的
两个对象通过hashCode()比较相等,当时equals()去做比较不一定相等,也就是hashCode()不是绝对可靠的
1.6 通过hashCode()和equals()搭配使用比较对象是否相等,是如何提高效率的
问题:对于一个对象中大量的成员信息,用equals比较会降低效率
解决:可以通过hashCode()进行比较,如果不相等则两个对象一定不同,如果相同,在通过equals()进行比较,这样既可以判断对象是否相同,又可以提高效率。
2.在HashSet集合中,通过hashCode()和equals(),保证元素的唯一性
HashSet保证集合唯一性的原理?
在通过查看add方法的源码,我们知道了添加功能的执行过程,是进行了数据的判断的。
这个判断的流程是:
首先比较对象的哈希值是否相同,这个哈希值是根据对象的hashCode()计算出来的。
如果哈希值不同,就直接添加到集合中
如果哈希值相同,继续执行equals()进行比较
返回的是true,说明元素重复,不添加
返回的是false,说明元素不重复,就添加
结论:如果我们使用HashSet集合存储对象,你要想保证元素的唯一性,就必须重写hashCode()和equals()方法。
3.结合项目使用,来体验应用的场景
问题:
Object类中equals方法是判断两个对象的地址是否相同,但是在hibernate中,不允许存在同类对象中有2个一样的实例。所有hibernate会通过equals()方法进行判断。
举例:
User u1 = new User("张三");
User u1 = new User("李四");
User u1 = new User("张三");
按照项目要求,用户只要名字相同,就表示同一个用户,所以我们认为,u1和u3是同一个人,也就是同一个对象。但是因为u1,u2,u3三个的内存地址不相同,所以hibernate会认为这是3个不同的对象。如何解决这个问题?我们会重写Object类中的equals方法
解决:
public boolean equals(Object arg0){
if(!(arg0 instanceof User)){
return false;
}
User user = ( User)arg0;
//如果名字相同,则表示属于同一个对象
if(user.getName().equals(this.getName())){
return true;
}else{
return false;}
}
这样在hibernate在插入数据的时候,如果传入一个叫“张三”的用户,hibernate会先判断有没有一个叫张三的用户,如果没有,就允许插入,如果有,就不会插入。这样就可以保证数据的一致性。