HashSet 存对象的时候是如何判断是不是同一个对象,其中含有重写equals方法和hashcode方法
以下面book这个类来说,它的hash值默认是按照里面的属性,进行循环
如上图所示,这里会进行循环遍历里面的值,最后会得到有个累加的值。
这是测试类:
这是实例对象,里面重写了equals方法和hashcode方法
第一次add的时候,集合里面没有对象,对象实例化,然后进入hashcode方法,返回,存进set集合中,图如下:
第二次add的时候,对象先实例化,然后走hashcode方法结果拿到的还是1,于是就要走equals方法,这里要注意,这里的equals方法里面传的是第一次集合里面的对象,这里要比
的肯定是这个对象,才能判断到底是不是重复的,我这里并没有用this去写,按照这个逻辑写的话,最后equals返回的是true,最后就认定为同一个对象了,所以才有后来的集合里面就一个对象
第三次add对象的时候,结果还是一样,这里第三个对象的时候我名字改成测试1,原本以为传的是three这个对象,后来发现equals方法里面this才是代表three这个对象,而equals方法里面的是要比的对象
最后由于hashcode和equals里面返回的是true就认定为同一个对象了。所以set集合里面还是一个对象
第四次add存对象的时候,由于自己改的hashcode方法逻辑,直接就返回了不同的hash值,hash不同了就是不一样的对象了,就会直接存进集合了,不会再走下面的equals逻辑了
最后set集合里面就两个对象了
总结:当hash值不同的时候会认为是两个不同的对象,当hash值相同时,会走下面的equals方法再去进行判断,目前只是走了里面的其中一个逻辑,equals返回值也相同,这个时候就认为这
两个对象还是同一个对象。
备注:后续会写一个equals方法返回不同值,hash值相同时会不会存进集合,答案是会存进集合的,后面补图