hashCode()方法与equals()方法
2024-08-30 10:25:49
摘自别人的评论:http://blog.csdn.net/fhm727/article/details/5221792
当向集合Set中增加对象时,首先集合计算要增加对象的hashCode码,根据该值来得到
一个位置用来存放当前对象。
如果在该位置没有一个对象存在的话,那么集合Set认为该对象在集合中不存在,直接
增加进去。
如果在该位置有一个对象存在的话,接着将准备增加到集合中的对象与该位置上的对象
进行equals方法比较。
如果该equals方法返回false,那么集合认为集合中不存在该对象,再进行一次散列,
将该对象放到散列后计算出来的地址中。
如果equals方法返回true,那么集合认为集合中已经存在该对象了,不再将该对象增加到集合中。
2
重写equals方法的时候必须重写hashCode方法。如果一个类的两个对象,使用equals
方法比较时,结果为true,那么这两个对象具有相同的hashCode。原因是equals方法为true,表明是同一个对象,它们的hashCode当然相同。(Object类的equals方法比较的是地址)
3
Object类的hashCode方法返回的是Object对象的内存地址。我们可以通过Integer.toHexString(newObject().hashCode());来得到。
Java里面的hashSet中,如何判断两个对象是否相等?
a.
判断两个对象的hashCode是否相等。
如果不相等,认为两个对象不相等。完毕
如果相等,转入2
b.
判断两个对象是否equals
如果不相等,认为两个对象不相等。
如果相等,认为两个对象相等。
最新文章
- C#设计模式-策略者模式
- android图片透明度跟缩放大小动画事件
- php集成动态口令认证
- .net 常用的命名空间和类
- strcmp函数使用总结
- mac下安装使用svn
- storm的作业单元:Topology
- U3D 飞机大战(MVC模式)解析--面向对象编程思想
- HTTP-304 NOT Modified
- 【数据库】MySQL中的共享锁与排他锁
- VS系列控制台闪退解决
- python操作mysql数据库增删改查的dbutils实例
- http协议介绍及get与post请求、响应状态码
- day5:字典dict
- RSA解密解密
- mysql 时间戳转换 、cnd、dns 通俗理解
- Fiddler配置
- 浏览器根对象window之history
- torch7 调用caffe model 作为pretrain
- Asp.net让某一页设置成gb2312或utf-8的方法