Java多线程验证CPU缓存一致性

CPU缓存

cpu运算速度大于内存读写速度,导致cpu花费大量的时间等待从内存读取数据和写入数据。缓存的交换速度比内存快很多,它的出现缓解了这个矛盾。

CPU缓存层级

双核CPU,每个CPU有独立的缓存L1、L2,有共享的缓存L3。在缓存中没有的情况下才会去内存中读取数据。

在这里插入图片描述

缓存行

cpu的缓存为了性能一般是以缓存行Cache Line为单位,一次性缓存一块区域的数据。
目前最常用的Cache Line大小为64字节。

缓存一致性

对于缓存行A,如果Cpu1对其中数据a进行修改,Cpu2缓存的数据块会失效,需要重新去内存中读取一次。
缓存一致性协议:https://www.cnblogs.com/z00377750/p/9180644.html

Java多线程验证

同一个缓存行,多线程用时429ms

在这里插入图片描述
用数组模拟出多个缓存行的情况,用时246ms

在这里插入图片描述

JDK8,可以采用@Contended注解。可以不受cpu缓存行字节数的限制,可以将属性作为独立的缓存行。需要加上:JVM -XX:-RestrictContended
有待验证

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值