V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
aheadlead
V2EX  ›  问与答

在需要高性能的编程中,需要注意多核 CPU 的缓存一致性 MESI 协议吗?

  •  
  •   aheadlead · 2017-09-28 11:15:19 +08:00 · 2024 次点击
    这是一个创建于 2395 天前的主题,其中的信息可能已经有所发展或是发生改变。
    6 条回复    2017-09-28 19:41:58 +08:00
    ipconfiger
        1
    ipconfiger  
       2017-09-28 11:18:57 +08:00
    需要
    aheadlead
        2
    aheadlead  
    OP
       2017-09-28 11:26:00 +08:00
    @ipconfiger 愿闻其详
    希望能给出一些参考资料,或者类似游戏引擎的代码参考,谢谢
    clearbug
        3
    clearbug  
       2017-09-28 12:33:33 +08:00 via Android
    这个东西不是都会在编程语言层面处理的么?我看 java 好像是这样的!楼主说的编程是用什么语言?
    gogohigh
        4
    gogohigh  
       2017-09-28 12:54:52 +08:00   ❤️ 1
    Java 有 JMM 处理
    xxzs
        5
    xxzs  
       2017-09-28 19:40:46 +08:00   ❤️ 1
    可以看看 folly, 比如 ProducerConsumer Queue 里面就对 cache line 做了特别处理,
    char pad0_[CacheLocality::kFalseSharingRange];
    const uint32_t size_;
    T* const records_;

    FOLLY_ALIGN_TO_AVOID_FALSE_SHARING std::atomic<unsigned int> readIndex_;
    FOLLY_ALIGN_TO_AVOID_FALSE_SHARING std::atomic<unsigned int> writeIndex_;

    char pad1_[CacheLocality::kFalseSharingRange - sizeof(writeIndex_)];
    };
    xxzs
        6
    xxzs  
       2017-09-28 19:41:58 +08:00   ❤️ 1
    有兴趣还可以研究一下 C++的 std::memory_order
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1117 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 18:28 · PVG 02:28 · LAX 11:28 · JFK 14:28
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.