Java并发-线程安全的集合类
注意,此处所提供的代码,都是基于JDK1.8版本,部分代码与之前版本存在较大差异
1、Hashtable:通过synchronized关键字保证线程安全
2、ConcurrentHashMap:效率比Hashtable高,主要体现在前者使用了锁分离技术,即代码块锁,而不是方法锁
保证线程安全的方法(JDK1.8中):在ConcurrentHashMap中,随处可以看到U, 大量使用了U.compareAndSwapXXX的方法,这个方法是利用一个CAS算法实现无锁化的修改值的操作,他可以大大降低锁代理的性能消耗。这个算法的基本思想就是不断地去比较当前内存中的变量值与你指定的一个变量值是否相等,如果相等,则接受你指定的修改的值,否则拒绝你的操作。因为当前线程中的值已经不是最新的值,你的修改很可能会覆盖掉其他线程修改的结果。这一点与乐观锁,SVN的思想是比较类似的。
3、CopyOnWriteArrayList:实现原理比较简单,就是利用之前写过的Java中的锁ReentrantLock进行加锁处理,写操作进行加锁处理,读操作则是利用复制容器的方式
4、CopyOnWriteArraySet:CopyOnWriteArrayList的装饰器模式
CopyOnWrite容器,即写时复制的容器,通俗理解就是当我们往一个容器中添加元素的时候,不直接往当前容器中添加,而是先将当前容器进行copy,复制出一个新的容器,然后新的容器里面添加元素,添加完元素之后,再将原容器的引用指向新的容器,这样做的好处是我们可以对CopyOnWrite容器进行并发的读,而不需要加锁,因为当前容器不会添加任何元素,但是添加元素的时候需要加锁,防止多个并发线程搞出多个复制容器来
所以CopyOnWrite容器比较多用于读多写少的并发场景,比如白名单,黑名单,商品类目的访问和更新等场景,
CopyOnWrite的注意:
1、减少扩容开销
2、尽可能使用批量添加
CopyOnWrite的缺点:
1、内存占用,复制容器的时候同时存在两个容器,而且写完之后,由于垃圾处理机制的原因,原容器可能还会留存一段时间
2、数据一致性问题,只能保证数据的最终一致性,不能保证数据的实时一致性
5、Vector 矢量队列,实现了List,通过synchronized关键字保证线程安全,跟Hashtable类似
6、StringBuffer和StringBuilder中,Stringbuffer是线程安全的,通过synchronized关键字保证线程安全。
最后复制粘贴一些关于CAS的文章链接,感觉说的挺好的
https://blog.csdn.net/hsuxu/article/details/9467651
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
新型恶意软件—— Grizzly攻击Telegram
简介 在过去的一个半月里,Talos观察到了一种新型恶意软件,它收集端到端加密即时消息服务Telegram的缓存和密钥文件。这款恶意软件最早于2018年4月4日发布,于4月10日出现第二个变种。 尽管第一个版本只能窃取浏览器凭证和cookie,以及系统上找到的所有文本文件,但第二个版本添加了收集Telegram桌面缓存和密钥文件的功能,以及Steam网站的登录信息。 Talos情报研究已经识别出了该恶意软件背后的作者。作者发布了几个YouTube视频,其中包含关于如何使用Telegram收集文件、劫持Telegram会话以及如何打包发布。 此恶意软件的运营者使用几个pcloud.com硬编码帐户来存储泄露信息。这些信息没有加密,这意味着任何有权访问这些凭证的人都可以访问已泄露的信息。 恶意软件主要针对俄语用户,并有意避免与匿名服务相关的IP地址。 TELEGRAM DESKTOP免责声明 恶意软件没有破坏或利用Telegram的任何漏洞。它影响Telegram的桌面版本,此版本不支持秘密聊天且具有较弱的默认设置。 https://core.telegram.org/tsi/e2ee-s...
- 下一篇
黑客盗走银行3亿比索|Rowhammer变体出现|DHS发布网络安全战略
上个月,墨西哥一家银行遭黑客攻击,估计被盗取3亿比索(超过1500万美元)。 墨西哥中央银行的官员发现了大量不寻常并且未授权的银行转账行为,从而对此进行了调查。由于这些资金并未全部被提现,因此还有部分可以被追回。然而,黑客到底使用了那种手段进行了攻击,目前尚不明确。但是,墨西哥的银行转汇系统SPEI(类似于SWIFT)相关的某个用于支付的第三方软件存在漏洞。黑客很可能通过这个点进行了攻击。 在此事件后,使用SPEI系统的金融机构都被告知要加强管理,去发现不正常的转汇行为已经确认操作的合规性。一旦遇到黑客攻击,金融机构不仅要蒙受经济损失,更要面对公众信誉的损失。当然,使用SWIFT系统的银行也需要警惕,大量黑客都在针对SWIFT系统进行攻击。孟加拉银行被黑客成功盗取8100万美金,而去年台湾银行被盗取6000万美金——这些都是利用了SWIFT的漏洞。 >> 自从Rowhammer攻击出现以来,研究人员发现了各种该类攻击的变体。而最近,另一种变体”Nethammer”出现了。这种攻击不需要在目标上有攻击者控制的代码,而是攻击在处理网络请求的时候使用非缓存或者清除指令的系统。研究...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Windows10,CentOS7,CentOS8安装Nodejs环境
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8编译安装MySQL8.0.19
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS8安装Docker,最新的服务器搭配容器使用
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS7,8上快速安装Gitea,搭建Git服务器