Disruptor十三问之三CPU缓存行填充

64位处理器缓存行的长度是64字节,java 64位long类型数据是8字节,也就是说一个缓存行需要8个long类型数据填充

如上图,假设volatile类型 head和tail在内存中地址连续,被两个CPU core1和core2都加载到各自的缓存行中,如果core1修改了head的值(缓存和内存中的值都被更新),

将整个缓存行为单位,标记为无效状态。

此时Core2再读取tail的值时,Core2嗅探到总线上关于tail已失效的标记,会重新从内存中读取数据到缓存。

这样效率就降低了,不仅缓存行变得无效,而且还增加了从内存读到缓存的开销。这个现象被称为“伪共享”

Disruptor框架通过增加补全ringBuffer序列号来保证它不会和别的对象放在一个缓存行中

public long p1, p2, p3, p4, p5, p6, p7; // cache line padding
private volatile long cursor = INITIAL_CURSOR_VALUE;
public long p8, p9, p10, p11, p12, p13, p14; // cache line padding

 

转载于:https://www.cnblogs.com/qiyu/p/4363519.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值