农历(八月十五)
老人
关于
友情链接
Toggle navigation
Harries Blog™
追心中的海,逐世界的梦
首页
编程技术
Java
软件架构
移动开发
后端
前端
大数据
数据库
算法
人工智能
测试
100 Days of AI Programming
代码管理
IT教程
springboot-demo
Java入门教程
bootstrap3
CSS
Apache基础教程
php
ionic 教程
Python
mysql教程
eclipse
Ubuntu VPS系统配置
AngularJS 教程
MongoDB教程
Struts2教程
springcloud-demo
Redis教程
Spring教程
Git教程
openfire参考指南
Jenkins进阶系列
Java设计模式
HBase教程
java-demo
Maven教程
hibernate教程
Docker 教程
memcached教程
Quartz指南
Ant教程
java实例教程
Hive教程
SpringCloud
ANTLR教程
XStream教程
Elastic-Job-Lite
Hazelcast教程
深入浅出MyBatis
ibaties教程
SVN教程
rabittmq教程
Hadoop教程
solr教程
WebService CXF学习
JPA教程
ActiveMQ中文指南
Java内存模型
dubbo教程
python3-demo
Linux入门视频教程
生活感悟
默认分类
博主自留地
一周一本书
一月一个人
互联网
互联网.出海
互联网.IPO
运维
Linux
docker
nginx
windows
操作系统
监控软件
vmware
虚拟化
tomcat
自动化
留言板
转载
发表于 2019年09月21日
浏览 (
801
)
评论 (0)
Java性能 -- 并发容器
某电商系统需要统计销量TOP 10的商品,通常用
哈希表
来存储商品和销量的键值对,然后使用
排序
获取销量TOP 10的商品
并发场景下不能使用HashMap
JDK
1.7
,在并发场景下使用HashMap会出现
死循环
,导致
CPU使用率居高不下
,而
扩容
是导致死循环的主要原因
JDK
1.8
,虽然修复了HashMap扩容导致的死循环问题,但在高并发场景下,依然会有
数据丢失
和
不准确
的情况
为了保证Map容器的
线程安全
,Java实现了
HashTable
、
ConcurrentHashMap
、
ConcurrentSkipListMap
HashTable、ConcurrentHashMap是
基于HashMap
实现的,适用于
小数据量
存取的场景
ConcurrentSkipListMap是
基于TreeMap
的设计原理实现的
ConcurrentSkipListMap是基于
跳表
实现的,而TreeMap是基于
红黑树
实现的
ConcurrentSkipListMap最大的特点是存取
平均时间复杂度
为
O(log(n))
,适用于
大数据量
存取的场景
HashTable / ConcurrentHashMap
在数据
不断地写入和删除
,且
不存在
数据
累积
以及数据
排序
的场景下,可以选用HashTable或者ConcurrentHashMap
HashTable使用
synchronized同步锁
修饰了put、get、remove等方法
在
高并发
场景下,读写操作都会存在大量
锁竞争
,给系统带来
性能开销
相比于HashTable,ConcurrentHashMap在保证
线程安全
的基础上兼具了
更好的并发性能
JDK 1.7中,ConcurrentHashMap使用了
分段锁Segment
减少了锁粒度,优化了锁的并发操作
JDK 1.8中,ConcurrentHashMap做了大量的改动,
摒弃了Segment的概念
synchronized同步锁在JDK 1.6的性能已经得到了很大的提升
在JDK 1.8中,
重启了synchronized同步锁
,通过synchronized实现
Node
作为锁粒度
put方法:没有哈希冲突时,使用
CAS
进行添加元素操作;有哈希冲突时,
通过synchronized将链表锁定
在统计销量TOP 10的场景下,首选ConcurrentHashMap
ConcurrentHashMap的
整体性能
要优于HashTable,但某些场景下ConcurrentHashMap不能替代HashTable
例如
强一致性
的场景,ConcurrentHashMap的get、size等方法都
没有加锁
,ConcurrentHashMap是
弱一致性
的
ConcurrentHashMap / ConcurrentSkipListMap
ConcurrentHashMap在
数据量比较大
的时候,
链表会转换为红黑树
红黑树在并发情况下,删除和插入过程有个
平衡
的过程,会涉及到
大量结点
,
竞争锁资源的代价相对较高
而
跳跃表
的操作针对
局部
,需要
锁住的结点少
,在并发场景下性能会更好一些
在
非线程安全
的Map中,基于
红黑树
实现的
TreeMap
在
单线程
中的
性能表现
并不比跳跃表差
因此
在
非线程安全
的Map容器中,使用
TreeMap
来存取
大数据
在
线程安全
的Map容器中,使用
ConcurrentSkipListMap
来存取
大数据
跳跃表
跳跃表是基于链表扩展实现的一种特殊链表,类似于
树
的实现
跳跃表不仅实现了
横向链表
,还实现了
垂直方向
的
分层索引
一个跳跃表由若干层链表组成,每一层都实现了一个
有序链表索引
,只有
最底层包含所有数据
每一层由下往上依次通过一个指针
指向上层相同值的元素
,每层数据依次减少,到最顶层只会保留部分数据
跳跃表利用了
空间换时间
的方法来提高查询效率,程序总是从
最顶层
开始查询访问,通过判断元素值来缩小查询范围
初始化的跳跃表
查询Key值为9的结点
新增Key值为8的结点,首先
新增
一个结点(
CAS操作
)到
最底层
的链表中
根据概率算出level值,再根据level值新建索引层,最后
链接
索引层的新结点(
CAS操作
)
删除Key值为7的结点,首先找到待删除结点,将其
value
值设置为
null
之后再向
待删除结点的next位置
新增一个
标记结点
,以便减少
并发冲突
然后让待删除结点的前驱结点直接越过本身指向的待删除结点,直接指向后继结点,中间要被删除的结点最终会被垃圾回收
最后判断此次删除后是否导致某一索引层没有其他节点了,并视情况删除该层索引
使用场景
HashTable:数据
强一致性
ConcurrentHashMap:(大部分情况)数据
弱一致性
ConcurrentSkipListMap:数据量在
千万
级别,且存在
大量的增删改
操作
原文
http://zhongmingmao.me/2019/08/30/java-performance-concurrent-container/
正文到此结束
赞
0
赏
分享
本文标签:
HashTable
线程
value
ORM
tab
并发
数据
同步
HashMap
key
删除
java
synchronized
UI
锁
一致性
https
空间
http
索引
map
缩小
高并发
ip
时间
统计
ConcurrentHashMap
安全
list
垃圾回收
node
2019
大数据
src
版权声明:
本文为互联网转载文章,出处已在文章中说明(部分除外)。如果侵权,请
联系本站长
删除,谢谢。
本文海报:
生成海报一
生成海报二
上一篇
Java日志框架:SLF4J详解
下一篇
Stream中map和flatMap差异分析
热门推荐
配置虚拟站点
浏览(8,891)
评论(20)
修改上传文件权限
浏览(10,670)
评论(18)
VPS 自我监控
浏览(9,384)
评论(23)
OpenVZ VPS 额外支持
浏览(9,434)
评论(17)
openfire数据库安装指南
浏览(19,028)
评论(0)
openfire定制指南
浏览(10,534)
评论(17)
Caffe 深度学习框架上手教程
浏览(14,935)
评论(0)
ReactiveCocoa入门教程:第一部分
浏览(15,713)
评论(0)
开源HIDS-OSSEC使用实例:监测CC攻击
浏览(15,640)
评论(0)
Decorators in ES7
浏览(20,291)
评论(4)
相关文章
殷鹏翔:51信用卡的日志分析变迁史和技术细节
Wechar Framework —— 微信开发框架
GSM Hacking:静默短信(Silent SMS)在技术侦查中的应用
CouchDB 视图简介及增量更新视图的方法
《神秘的程序员们》漫画50:程序员该如何找合租室友?
2017年试试Web组件化框架Omi
Java程序员面对未来架构,如何追赶技术革新的脚步?
【spring 国际化】springMVC、springboot国际化处理详解
Forge 能量系统简述(五)
集成mybatis以及orm框架和插件的个人看法
说给你听
本文目录
随机标签
交易额912.17亿
WMS
AJ-Captcha
散列索引
瑷珲条约
单间出租
ZoneOffset
5701
欧洲企业
pyftpdlib
优惠政策
Swift
Hadoop
地铁
网站销售
源码
拒绝策略
@PathVariable
ETL
产品导购
JPA安装配置
知识共享协议
Runnable
ConcurrentHashMap
example
Architect
写诗
cglib
Presto
死对头
Spring Cloud Function
酒店
孕产妇用品
Struts2
Tesseract
copyProperties
Graylog
合伙人
XMLStatementBuilder
k8s
ask
数据挖掘
TCP
年入 1 亿元
多个字段
物业态度嚣张
辉哥
软件
web全栈工程师
内容展示
MySQL日志
书籍教程
springboot-demo
Java入门教程
bootstrap3
CSS
Apache基础教程
php
ionic 教程
Python
mysql教程
eclipse
Ubuntu VPS系统配置
AngularJS 教程
MongoDB教程
Struts2教程
springcloud-demo
Redis教程
Spring教程
Git教程
openfire参考指南
Jenkins进阶系列
Java设计模式
HBase教程
java-demo
Maven教程
hibernate教程
Docker 教程
memcached教程
Quartz指南
Ant教程
java实例教程
Hive教程
SpringCloud
ANTLR教程
XStream教程
Elastic-Job-Lite
Hazelcast教程
深入浅出MyBatis
ibaties教程
SVN教程
rabittmq教程
Hadoop教程
solr教程
WebService CXF学习
JPA教程
ActiveMQ中文指南
Java内存模型
dubbo教程
python3-demo
Linux入门视频教程
近期评论
匿名yangdongzhen590
哥太牛了
阳光星河
是呀,看您的IP显示在美国,还以为您移民了
admin
没有呢,你是看IP发现的吧
阳光星河
对,今年在湖南老家,过完年再看吧,怎么看您去美国了呢
admin
你回老家发展了嘛?不再广东了嘛?
阳光星河
如此优秀的操作,我都没想过这个问题
阳光星河
没有项目,个人能长期使用不
Harrries
已经加上
阳光星河
阳光星河 https://www.276227.com
Harrries
域名是什么?我重新加上
随机文章
站长推荐
近期文章
1
每周 Swift 社区问答 2016-03-23(第十四期)
2
【Mocha.js 101】钩子函数
3
重载一个 skynet 中的 lua 服务
4
通过Jinq简化数据库查询
5
Scala中心基金会成立
6
JEP 286局部变量类型推断调查结果
7
Bloomberg开源面向OCaml的JavaScript后端BuckleScript
8
Android开发周报:Google Play提供试用功能、MVP架构设计
9
Firefox Developer Edition推出弹出窗口调试
10
《Clojure Recipes》书评与问答
1
VPS 自我监控
2
springboot接入多个ES启动时候自检报错
3
配置虚拟站点
4
openfire协议支持指南
5
修改上传文件权限
6
OpenVZ VPS 额外支持
7
2015年北京下第一场雪留念
8
openfire定制指南
9
mysql存储过程实例一:游标的使用
10
Linux删除或者新增SWAP分区
1
又学一招:Excel 数据对比及 VBA 实现方案
2
EasyExcel 读取数值精度丢失问题与解决方案
3
mongodb重命名和创建索引
4
WordPress 删除尚未附加的图片:优化网站存储空间的实用指南
5
OVHcloud 美区购买服务器指南
6
拿到兑换码后,如何在腾讯 EdgeOne 控制台兑换、接入并体验 CDN 加速?
7
如何让你的 GitHub 开源项目获得腾讯 EdgeOne 免费 CDN 加速:完整申请流程解读
8
️ Netcup 最便宜服务器购买指南(2025 最新版)
9
深入探索Java虚拟机的神秘接口:JVMTI
10
只需要75美元就可以拥有一个终身免费的邮箱服务(250G+15个域名)
网站信息
文章总数:82,779 篇
文件总数:210,936 个
标签总数:2,449 个
分类总数:86 个
留言数量:2,580 条
在线人数:649 人
运行天数:4,726天
最后更新:2025年10月05日09点
×
输入密码查看文章详情
×
搜索文章
搜索
热门搜索:
Java
Springboot
Linux
Maven
Bootstrap
阿里云
×
评论信息框
可以通过QQ号实时获取昵称和头像
QQ
昵称
邮箱
网址
提交评论
×
山无棱江水为竭,冬雷震震夏雨雪,才敢请君舍
支付宝
微信
转账时请备注“
博客赞助
”
Loading...