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

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

  •  
  •   aheadlead · 2017-09-28 11:15:19 +08:00 · 1312 次点击
    这是一个创建于 785 天前的主题,其中的信息可能已经有所发展或是发生改变。
    6 回复  |  直到 2017-09-28 19:41:58 +08:00
        1
    ipconfiger   2017-09-28 11:18:57 +08:00
    需要
        2
    aheadlead   2017-09-28 11:26:00 +08:00
    @ipconfiger 愿闻其详
    希望能给出一些参考资料,或者类似游戏引擎的代码参考,谢谢
        3
    clearbug   2017-09-28 12:33:33 +08:00 via Android
    这个东西不是都会在编程语言层面处理的么?我看 java 好像是这样的!楼主说的编程是用什么语言?
        4
    gogohigh   2017-09-28 12:54:52 +08:00   ♥ 1
    Java 有 JMM 处理
        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_)];
    };
        6
    xxzs   2017-09-28 19:41:58 +08:00   ♥ 1
    有兴趣还可以研究一下 C++的 std::memory_order
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   3779 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 24ms · UTC 09:53 · PVG 17:53 · LAX 01:53 · JFK 04:53
    ♥ Do have faith in what you're doing.