2019独角兽企业重金招聘Python工程师标准>>>

注意:JEP142规范,Reduce Cache Contention on Specified Fields。

1.伪分享情况下,JDK8上,偏向于使用@Contended

伪分享的情况下,可以使用填充和JDK8的@Contended注解。

但是实验结果证明数据填充并不能做的很好,因为不同的机器、不同的操作系统对缓存行的使用情况不一样,我们很难确定我们机器上的缓存使用机制就是如我们设想的那样,所以建议使用JDK8的@Contended注解。

为什么偏向于使用@Contended注解:

  1. 我自己用代码试验,试验了用数据填充、用@Contended注解,从结果来看,@Contended确实可以提升几倍,比填充好。
  2. 另一个证据是国外的这篇博客,这篇博客解释了,为什么@Contended注解比数据填充好,原因是CPU执行instruction时,会prefetch。很多人说,填充到64bytes就可以了,但我发现这种说法的作者缺少额外的了解,我们对操作系统底层还是了解的不够。

2.@Contended注解的value

List-1 Intellij Idea中打开的Oracle JDK @Contended没有注释

package sun.misc;import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.TYPE})
public @interface Contended {String value() default "";
}

List-2 来看openJDK的@Contended注解,源码地址

...这里有很多注释,自行查看源码...@Retention(RetentionPolicy.RUNTIME)
@Target({ElementType.FIELD, ElementType.TYPE})
public @interface Contended {/*** The (optional) contention group tag.* This tag is only meaningful for field level annotations.** @return contention group tag.*/String value() default "";
}

openJDK的Contended.java中有详细的注释,这个value只有在类属性上才有意义,表示"contention group tag",理解字面意思,但是没有理解具体含义。查google,查到Stackoverflow上别人的回复,说的和List-2注释差不多,理解字面意思,但是没理解含义,原文地址。我把别人的回答截图,如下图1。

图1 Stackoverflow上关于@Contended的value回答

3. JDK8中使用@Contended的类举例

ForkjoinPool的内部类WorkQueue

图1 JDK8中ForkjoinPool的WorkQueue

List-3 JDK8中Thread内部属性,这几个属性与ThreadLocalRandom有关

    // The following three initially uninitialized fields are exclusively// managed by class java.util.concurrent.ThreadLocalRandom. These// fields are used to build the high-performance PRNGs in the// concurrent code, and we can not risk accidental false sharing.// Hence, the fields are isolated with @Contended./** The current seed for a ThreadLocalRandom */@sun.misc.Contended("tlr")long threadLocalRandomSeed;/** Probe hash value; nonzero if threadLocalRandomSeed initialized */@sun.misc.Contended("tlr")int threadLocalRandomProbe;/** Secondary seed isolated from public ThreadLocalRandom sequence */@sun.misc.Contended("tlr")int threadLocalRandomSecondarySeed;

List-4 JDK8中Striped64的内部类Cell

   /*** Padded variant of AtomicLong supporting only raw accesses plus CAS.** JVM intrinsics note: It would be possible to use a release-only* form of CAS here, if it were provided.*/@sun.misc.Contended static final class Cell {volatile long value;Cell(long x) { value = x; }final boolean cas(long cmp, long val) {return UNSAFE.compareAndSwapLong(this, valueOffset, cmp, val);}// Unsafe mechanicsprivate static final sun.misc.Unsafe UNSAFE;private static final long valueOffset;static {try {UNSAFE = sun.misc.Unsafe.getUnsafe();Class<?> ak = Cell.class;valueOffset = UNSAFE.objectFieldOffset(ak.getDeclaredField("value"));} catch (Exception e) {throw new Error(e);}}}

在这里就只是举这几个例子

转载于:https://my.oschina.net/u/2518341/blog/1838186

JDK之伪分享的情况下该使用填充还是@Contended相关推荐

  1. 1.什么情况下发生GC

    目录 一:jvm运行时数据区的划分 二:堆区的划分(where) 三:什么情况下发生GC(when) 四:哪些内存需要回收(垃圾对象who) 五:GC如何回收(how) 六:jvm的内存回收过程 七: ...

  2. 《Thinking in Bets》读书分享 - 如何在信息不完全情况下做出更好的决策(1)...

    读书分享系列之一 - <Thinking in Bets>(1) 从一次误机事件说起 上周,我和gengqian.zijing等同学一起去杭州参加集团效能大会.qian妹子选择了晚上9点多 ...

  3. 《Thinking in Bets》读书分享 - 如何在信息不完全情况下做出更好的决策(1)

    读书分享系列之一 - <Thinking in Bets>(1) 从一次误机事件说起 上周,我和gengqian.zijing等同学一起去杭州参加集团效能大会.qian妹子选择了晚上9点多 ...

  4. 【Java】JDK 7 HashMap 头插法在并发情况下的成环问题

    CONTENT 问题描述 成因详解 总结 Reference 问题描述 JDK 7 的 HashMap 解决冲突用的是拉链法,在拉链的时候用的是头插,每次在链表的头部插入新元素.resize() 的时 ...

  5. ios 开发 微信分享失败_一个失落的孩子如何在失败的情况下从失败变成了iOS开发人员...

    ios 开发 微信分享失败 by Jordan LaGrone 乔丹·拉格隆(Jordan LaGrone) 一个失落的孩子如何在失败的情况下从失败变成了iOS开发人员 (How a lost kid ...

  6. 《Thinking in Bets》读书分享(1) - 如何在信息不完全情况下做出更好的决策

    读书分享系列之一 - <Thinking in Bets>(1) 从一次误机事件说起 上周,我和gengqian.zijing等同学一起去杭州参加集团效能大会.gengqian选择了晚上9 ...

  7. 特殊情况下需要分享屏幕? 基于 flask 的微型屏幕共享服务器(可实现屏幕共享)

    前言: 今天给大家分享一个有趣的小项目,话说在很久以前我需要做一个报告,原来的屏幕共享软件出了点问题,于是临时写了这个程序来应急,效果还不错,今天分享给大家,如果遇到某些特殊情况,可以用来应急 一.使 ...

  8. mysql锁表查询_Mysql数据库锁情况下开启备份导致数据库无法访问处理分享

    [背景简介] MySQL是一种开放源代码的关系型数据库管理系统(RDBMS),因为其速度.可靠性和适应性而备受关注.大多数人都认为在不需要事务化处理的情况下,MySQL是管理内容最好的选择.mysql ...

  9. 该不该用存储过程?什么情况下使用存储过程?

    转自:https://www.cnblogs.com/gxbk629/p/4505844.html 本篇文章讨论并不是:不要使用存储过程,因为有些事情还是要存储过程来完成,不可能不用.而是关于:&qu ...

最新文章

  1. iOS面试准备之思维导图
  2. g++代码编译用选项-O3前后对比,前后执行时间对比如下
  3. JSR303(Bean Validation 1.0)
  4. Lightroom Classic CC8.2安装教程 IT宝盒 10-14 20:32
  5. Docker之docker简介及其优势
  6. JSP中javaBean和Servlet理解
  7. 包装严重的 IT 行业,作为面试官,我是如何甄别应聘者的包装程度
  8. Maven报错“未结束的字符串字面值”
  9. poj 2831(次小生成树)
  10. rust军用船指令_RUST物品指令清单(英文版)
  11. 引用另一个Android工程的方法详解
  12. Mybatis的几种传参方式
  13. ActivityManager: Warning: Activity not started,...
  14. excel怎么设置打印区域_淘宝卖家想要打印快递单怎么设置
  15. buuctf-misc部分wp(更新一下)
  16. XSS进阶二 ——合天网安实验室学习笔记
  17. 【联盛德W806上手笔记】十、ADC
  18. excel启用宏在哪里_Excel 2010在不启用的情况下运行宏
  19. 【linux系统用户管理】
  20. python中格式化输出的作用是什么_python格式化输出是什么意思

热门文章

  1. 卷土重来 263网络通信“继续上市”引来经营质疑
  2. docker清理空间
  3. 关于golang注释
  4. Umi + AntD Pro 项目搭建
  5. 全球肝脏肿瘤病灶区CT图像分割挑战大赛,联想E-Health夺得冠军
  6. computer-02 显卡
  7. 多级队列调度和多级反馈队列调度算法的实现
  8. java int是否为null_java怎么判断int是否为空?
  9. c语言用栈编写计算器程序,用c语言实现简易的计算器四则运算的代码最好用栈方法实现,该怎么解决...
  10. python数组赋值_基本Numpy数组值赋值