JDK8 推荐  LongAdder替代 AtomicInteger,

AtomicInteger内部是实现使用 (网友使用jad反编译源码 参考 http://ifeve.com/enhanced-cas-in-jdk8/),高并发场景compareAndSwapInt 会不断的试错,有性能问题。

public final int getAndAddInt(Object obj, long l, int i) {
int j;
do
j = getIntVolatile(obj, l);
while(!compareAndSwapInt(obj, l, j, j + i));
return j;
} public native int getIntVolatile(Object obj, long l);
public final native boolean compareAndSwapInt(Object obj, long l, int i, int j);

LongAdder在AtomicLong的基础上将单点的更新压力分散到各个节点,在低并发的时候通过对base的直接更新可以很好的保障和AtomicLong的性能基本保持一致,而在高并发的时候通过分散提高了性能。

将待处理的数据,通过hash计算分散到Cell数组中分别处理,最后在汇总计算。

注意casBase   ==>   !casBase(b = base, b + x);表示CAS更新操作;如果一个线程去CAS失败,那么表示正在有一个线程正在CAS操作,表示竞争激烈;

   // LongAdder
public void add(long x) {
Cell[] as; long b, v; int m; Cell a;
// !casBase(b = base, b + x);表示CAS更新操作;如果一个线程去CAS失败,那么表示正在有一个线程正在CAS操作,表示竞争激烈;
if ((as = cells) != null || !casBase(b = base, b + x)) {
boolean uncontended = true;
if (as == null || (m = as.length - 1) < 0 ||
(a = as[getProbe() & m]) == null ||
!(uncontended = a.cas(v = a.value, v + x)))
longAccumulate(x, null, uncontended);
}
}

LongAddr在高并发的时候,Cell数组的汇总计算会不准确, 在高并发获取全局唯一ID的时候,使用AtomicLong而不是LongAddr

参考

https://www.jianshu.com/p/67a75e36166f

https://www.cnblogs.com/gosaint/p/9129867.html

最新文章

  1. Python学习总结 01 配置环境
  2. js生成二维码(jquery自带)
  3. 在powerdesigner中,一个table,怎么在diagram中创建多个symbol
  4. JTMz换路径导致MySQL服务不能启动的问题
  5. Java实现---堆排序 Heap Sort
  6. 7.5---两个正方形分成对半的直线(CC150)
  7. Hadoop第4周练习—HDFS读写文件操作
  8. boost序列化
  9. js笔记--json
  10. Codevs 5056 潜水员
  11. 关于Oracle连接超时的问题
  12. Android 夜间模式changeskin小结
  13. 安装shellinabox-master
  14. 主席树套树状数组——带修区间第k大zoj2112
  15. ISP PIPLINE (十三) CSM/CSC(color space matrix/convert)
  16. Laravel5:重定向 redirect 函数的详细使用
  17. 【读书笔记】iOS-属性
  18. Vue(九):样式绑定v-bind示例
  19. NDK环境搭建方法2
  20. 使用extract-text-webpack-plugin提取css文件

热门文章

  1. JavaScript中callee与caller,apply与call解析
  2. Spring boot中使用log4j记录日志
  3. NYOJ 1022 合纵连横 (并查集)
  4. # 2018高考&amp;自主招生 - 游记
  5. 爬行百度标题&amp;URL案例
  6. Linux系统调用、新增系统调用方法【转】
  7. Linux下多路径multipath配置【转】
  8. 架构师必须搞懂DNS【转】
  9. juery下拉刷新,div加载更多元素并添加点击事件(二)
  10. tp 框架 利用反射实现对象调用方法