• 其他语言



如何在高速缓存边界对齐数据结构
页面和feed选项
打印 | 通过电子邮件发送给朋友 | 联系支持中心
收藏此页
Digg此页 | 添加到您的del.icio.us帐号
给此页评分
论坛标签

搜索标签
 

挑战
确保每个同步变量都独自位于一个高速缓存行上。 正如我们在如何避免错误共享 中所讨论的那样,当将同步结构拉伸至高速缓存行的大小后,必须确保同步结构在高速缓存边界上对齐。

解决方案
利用下面给出的适当编码技术,将数据结构在高速缓存边界上对齐。 将同步结构拉伸为高速缓存行的大小并不能说是完全大功告成。您还需确保同步结构在高速缓存边界上对齐。同步变量不能与另一个同步结构位于相同的高速缓存行上,如果同步结构没有在高速缓存边界上对齐,则同步变量无法独自位于一个高速缓存行上。可以采用下面两种技术中的一种来执行对齐。

针对动态内存,采用如下代码片断:

struct syn_str { int s_variable; };

void *p = malloc ( sizeof (struct syn_str) + 127 );

syn_str * align_p = (syn_str *)( (((int) p) + 127) & -128 );

当使用英特尔 C/C++ 编译器时,也可采用下面的代码片断:

_declspec(align(128)) struct syn_str aligned_structure;

欲了解这些代码片断的更多内容,以及它们在实际情形中的使用,请参阅本主题 "资料来源" 中引用的应用注释。

资料来源
我们邀请您在本页 发表评论 (不受客服控制),或直接向我们的支持中心 提问.