十二、高并发统计为什么用LongAdder

LongAdder,在无竞争的情况下跟AtomicLong一样,对同一个base进行操作。当出现竞争关系时则是采用化整为零的做法,用空间换时间,用一个数组cells,将一个value拆分进这个数组cells。多个线程需要同时对value进行操作时候,可以对线程id进行hash得到hash值,再根据hash值映射到这个数组cells的某个下标,再对该下标所对应的值进行自增操作。当所有线程操作完毕,将数组cells的所有值和无竞争值base都加起来作为最终结果。

 

源码解读:判断cell的新建和扩容

 

cell的创建、赋值、扩容流程

 

AtomicLong、LongAdder分析比较

AtomicLong

原理:CAS+自旋,incrementAndGet。

场景:低并发下的全局计算。AtomicLong能保证并发情况下计数的准确性,其内部通过CAS来解决并发安全性的问题。

缺陷:高并发后性能急剧下降,AtomicLong的自旋会成为瓶颈。

LongAdder

原理:CAS+Base+Cell数组分散,空间换时间并分散了热点数据。

场景:高并发下的全局计算。

缺陷:sum求和后还有计算线程修改结果的话,最后结果不够准确,但最终一致性。

 

 

 

posted @   幻月hah  阅读(154)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
历史上的今天:
2019-12-30 vue防止多次点击,重复请求
点击右上角即可分享
微信分享提示