关于 L3 缓存行 cacheLIne 的研究!还是对程序有举足轻重的作用!

 https://www.cnblogs.com/PurpleTide/archive/2010/11/25/1887506.html 
CLR via C# 读书笔记 2-3 Cache Lines and False Sharing(高速缓冲区和错误共享???)
关于CPU中缓存行的问题。 volatile 修饰的字段 会 lock 整个缓存行,而 每个缓存行占用64KB ,老的CPU32KB。。
因此class A{ int a ,int b} 如果A.a 被线程1 修改, 线程2 就无法修改以及访问 A.b ,直到A.a被线程1修改完成 再次写入内存 ,
线程2 才能访问 内存中的A.b ,这就是 内存锁定(跟CPU中L3缓存中的缓存行锁定是同步的。
因此 一个类最好 set 内存布局,int a 占用64个字节,int b 偏移64个字节后存放。这样就能 a ,b 字段 各占用一个 L3 缓存行。不同线程读写a,b 时无需等待另一个线程读写完毕。
 https://blog.csdn.net/sprayabc/article/details/8658369 
以下是最最最长尽的多核CPU 以及L3缓存的缓存行,设计过程。
 https://www.cnblogs.com/jokerjason/p/9584402.html 

posted on 2019-08-17 17:33  infinitable  阅读(...)  评论(... 编辑 收藏

导航