30.伪共享?

伪共享是多线程编程中的一种性能问题,由于CPU缓存按缓存行读写,导致多个线程修改同一缓存行的不同变量时产生性能下降。此现象源于同一缓存行内的变量不能并发修改。解决办法包括字节填充和使用JDK8的Contended注解来防止变量被分配到同一缓存行。
摘要由CSDN通过智能技术生成

1了解过什么是“伪共享”吗?

CPU缓存从内存读数据时,是按缓存行读取的,即使只用到一个变量,也要将整行数据进行读
取,这行数据量可能包含其他变量。当多个线程同时修改同一个缓存行里的不同变量时,由于
同时只能有一个线程在操作,所以相比将每个变量放到不同缓存行里,性能会有所下降。多个
线程同时修改了同一个缓存行上的不同变量,由于不能并发修改,所以称为“伪共享”。

2.“伪共享”出现的原因是什么?

因为CPU缓存和内存交换数据的单位是缓存行,而同一个缓存行里的多个变量不能同时被多个
线程修改。

3.如何避免“伪共享”?

  1. 字节填充(创建变量时,使用字段对其进行填充,避免多个变量被分派到同一个缓存行
    里)。
  2. JDK8提供了一个Contended注解来解决伪共享。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值