前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >并发map并发设计演进

并发map并发设计演进

作者头像
蛋蛋编程手记
发布2022-07-27 13:47:31
4220
发布2022-07-27 13:47:31
举报
文章被收录于专栏:蛋蛋编程手记蛋蛋编程手记

concurrentHashMap的底层指导思想之前有提过,就是通过细化锁的粒度来优化并发情况下的锁冲突从而实现高性能的。这种思想在很多设计中都能看到,比如Innodb的行级锁概念。

jdk1.8之前,并发map通过引入segment来细化锁的粒度,就是把原本的数组分到多个不同的段里,每个段单独管理自己的数组,段与段之间不冲突,即使数组扩容也是段内部的数组扩容。

segment长度默认是16,可以构造时指定,后面不会变化,所以并发度主要还是看segment的个数了。数据越多并发冲突的概率越大

jdk1.8废弃了segment的概念,锁粒度更加的细化,直接给数组的链首或树根元素加锁。只要没有hash冲突就没有并发冲突。数据多了,数组会扩容,并发冲突的概率并没有变大

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-05-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 蛋蛋编程手记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档