2020-12-22

cpu

Rgtister : 寄存器
ALU: 运算单元
PC : programe control 程序计数器

缓存行伪共享

cpu运行处理数据时,根据局部性原理会加载一块连续内存中的数据,该内存称作缓存行,windows操作系统中缓存行对应的是64字节大小。对于多线程处理的情况,多个线程同时处理该缓存行中的不同数据,根据MESI协议会频繁的导致cpu读取缓存行中的数据失效,影响cup处理的效率。

处理方式: 对齐填充

乱序

cup load指令加载内存中数据时,会优先执行其他的指令

禁止乱序

cup层面: intel 原语 (lfence、sfence、mfence)或者锁总线
jvm 层面: happens-before 或者 4个内存屏障 (ll、ls、sl、ss)
as if serial : 不管硬件什么顺序,程序执行结果不变 ,类似于serial

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值