[Linux] 理解CPU缓存的伪共享问题

CPU是有高速缓存的 , 三级缓存分别是 L1 ,   L2   ,   L3

L1缓存最贴近CPU , 所以速度也最快

数据在缓存中是一行一行存储的 , L1缓存一般的一行缓存64字节

一行能缓存64个字节  , 因为一个变量可能没有64字节大小 , 所以可能会缓存好几个变量

缓存需要保证一致性, 也就是当变量修改的时候 , 缓存必须得失效 , 重新在内存中读取变量加载到缓存里

当一行里有好几个变量的时候 , 其中一个变量修改了 , 这一行的数据都得失效 

并且同一时间只允许一个线程操作缓存行 ,

当并发比较高修改比较频繁时候 , 缓存的性能就下降了很多 , 这就是伪共享问题

一般解决这个问题是用的内存对齐填充来解决 , 也就是我一个变量占满这一行64字节 , 当然这样也比较浪费缓存

我们常说的局部性原理也与CPU缓存有关 ,

当我们使用数组的时候 , 内存地址是连续的 , 这样就很有可能放在一行里 , 每次CPU从缓存里读一行就能读到相邻的变量 , 速度会很快

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值