首页 > 代码库 > Java ConcurrentHashMap分析
Java ConcurrentHashMap分析
ConcurrentHashMap就是HashMap的线程安全版本,值得一提的是,ConcurrentHashMap并没有用一个锁来保护整个哈希区,而是使用了16个锁,将哈希区分成了16个桶,每一个锁控制一个桶,即锁分段,这样子可以更加细粒度的锁对象,所以最大提供16个并发的读写,来提高吞吐量。
但是这种技术也带来了不好的地方,比如有些方法需要扫描这个哈希区,如size()方法或者是containsValue()方法,这样子将使用多个锁而不是一个锁来实现,而当需要多把锁的时候,就需要某些技术,如按顺序上锁来避免死锁。
原文:http://blog.csdn.net/hongchangfirst/article/details/39667989
作者:hongchangfirst
hongchangfirst的主页:http://blog.csdn.net/hongchangfirst
Java ConcurrentHashMap分析
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。