A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 坚持525 中级黑马   /  2014-10-16 21:11  /  1797 人查看  /  10 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

看了张老师的视频,自己理解的hashCode的作用:
  hashCode只有在hashSet集合下有用,如果两个对象的equals相等,就让他的hashCode的也相等。如果不是hashSet集合就没有必要用到hashCode。
关于java中的内存泄漏的现象:
当集合中的对象不用了,却一直没有被释放掉,造成了内存的泄漏,如果修改了hashSet集合中对象的值,hashCode值也就改变了,所以就删不掉了,
注:这段话是张老师在ReflectTest2.java中有演示,可以自己在琢磨琢磨.
感觉现在自己都开始话唠了,觉得是不是东西太多了,记不住,所以来发个帖子,方便以后自己看看,养个好习惯吧!

评分

参与人数 1技术分 +1 收起 理由
杨佳名 + 1

查看全部评分

10 个回复

倒序浏览
你好像说翻了,应该是先比较hashCode,后比较equals。

我是这么理解的
hashCode和equals是 HashSet下用于做对象比较的工具。
当两个元素进行比较时,先比较hashCode,如果hashCode值相等,说明两个元素有可能相同,这时,再用equals比较两个元素的内容,如果还是相同,说明是同一个元素,因为set集合下,不允许两个相同的元素存在,所以用2次比较排除相同元素。

但是,我们比较的元素有时候是new出来的,因为new出来的元素hashCode是不一样的。
如果当hashCode值不同时,jvm不会认为它们是同一个元素。
我们就要手动覆写底层的hashCode方法,例如
  1. public int hashCode()  
  2.     {  
  3.         return name.hashCode()+age ;   
  4.     }  
复制代码

这样通过让元素内容运算后作为hashCode的值去进行比较,可以排除new对象hashcode不同的问题。同样可以找出可能重复的元素。

我是这么记这个问题的,哈哈

评分

参与人数 1技术分 +1 收起 理由
杨佳名 + 1 赞一个!

查看全部评分

回复 使用道具 举报
nerveva2000 发表于 2014-10-17 10:37
你好像说翻了,应该是先比较hashCode,后比较equals。

我是这么理解的

恩恩,确实这样的,你申请几期的呢?
回复 使用道具 举报
坚持525 发表于 2014-10-17 21:08
恩恩,确实这样的,你申请几期的呢?

还在学习中,刚看完集合,很想去深圳的50期,不知道自己能否赶上,先扎实学好,抓紧进度。。。
回复 使用道具 举报
nerveva2000 发表于 2014-10-18 14:32
还在学习中,刚看完集合,很想去深圳的50期,不知道自己能否赶上,先扎实学好,抓紧进度。。。 ...

加油!我能快点,我申请了北京的,加油!!1
回复 使用道具 举报
hashCode 功能不是判断相等 主要是提高判断的效率 也就是检索效率 试想如果每存入一个元素 都要与所有的对象比较一通 那元素数量一大起来 这个集合就可以放弃了  哈希值是一个整数 是存在hashTable内部数组的角标里 结合老张说的 每个哈希值就像一个区 ; 而且HashTable在创建的时候可以设置这个数组大小
下面是个人看法,想真正了解还得自己看哈希值原理:
对象元素可以无限制 HashTable设置的哈希值范围却有大小 就注定了哈希值主要用于提高效率的功用  所以为了准确判断是否相等就使用equals来弥补这个不足
回复 使用道具 举报
郑飞 高级黑马 2014-10-20 19:54:05
7#
只是在网上看到过这么说的 可惜老张只是点到为止 多的要自己看了
回复 使用道具 举报
踏云 中级黑马 2014-10-21 00:27:27
8#
话唠才好啊
回复 使用道具 举报
Sxxjava 中级黑马 2014-10-21 00:28:49
9#
话唠啊,顶一个
回复 使用道具 举报
同意2楼,老毕就是这么讲的
回复 使用道具 举报
郑飞 发表于 2014-10-20 19:51
hashCode 功能不是判断相等 主要是提高判断的效率 也就是检索效率 试想如果每存入一个元素 都要与所有的对 ...

谢谢大神的提点,谢谢!:D
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马