码迷,mamicode.com
首页 > 其他好文 > 详细

对hashmap与hashcode()、equals()的理解

时间:2016-12-08 18:42:45      阅读:201      评论:0      收藏:0      [点我收藏+]

标签:map   val   put   shc   node   code   ash   equal   问题   

1.equals方法没被重写的时候   比较的只是对象的地址  重写之后 比较的才是对象里的内容

2.重写equals的时候 务必需要重写hashcode 不然在用到容器的时候 会出现问题 因为容器会去判断新加入的对象的hashcode 在集合中是否存在 再去判断对象的内容

3.hashmap的理解

hashmap其实就是数组+链表   这里所谓的链表 无非就是 在hashmap里定义了一个静态Node类 这个类有Node next这个引用 可以指向当前下一个在当前索引下标下的Node节点

进行put的时候 会根据传入的key进行hash(key.hashcode())  然后算出索引 去数组里找

1.如果没找到下标 那么直接addentry()

2.存在下标的话(其实就是链表的第一个元素),判断是否存在相同的key 相同那么就覆盖原来的value,不同就是直接放在链表的第一个,为什么放在第一个,那是因为定义的Node节点,属就是Node next

3.同时有两个线程put的时候 一旦超出数组长度  会进行resize双倍扩容 此时存在对table这个公共变量资源 进行竞争  所以存在多线程安全问题  

所以在判断高并发 高访问的时候 可以考虑用concurrenthashmap

对hashmap与hashcode()、equals()的理解

标签:map   val   put   shc   node   code   ash   equal   问题   

原文地址:http://www.cnblogs.com/vinplezhang/p/6145631.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!