原文:http://blog.youkuaiyun.com/sy8111/archive/2006/09/05/1178107.aspx
下面用一个简单的小程序来验证False Sharing对性能的影响。
这个小程序同时运行两个线程,对同一块内存区域的临近位置进行int大小的多次读写。线程1读写第1个int值,线程2读写第2个int值。按照预想,如果两个int相隔太近,落入同一个cache line,两个线程就会因为"伪共享"而花费额外的时间进行缓存一致性通信和维护,造成性能下降。
TestFalseSharing.cpp 是主程序,Thread.h/cpp 是对Win32 Thread API的简单封装,Timer.h/cpp是对CRT time函数的简单封装。
运行结果
数据距离(DISTANCE) 花费时间(秒)
4 21
8 21
16 10
32 10
可以看到,当距离达到16个int,也就是64字节的时候,"伪共享"消失,而64字节也就是我的机器的cache line 大小。