并行化的版本为什么比单线程版本慢?有误差共享吗?
创始人
2024-12-18 17:00:06
0

错误共享是指当多个线程试图同时更新同一缓存行的不同变量时发生的现象。由于缓存经常被不同的核心和线程共享,因此频繁的内存访问可能会出现错误共享,这会导致性能下降。

解决错误共享的方法是通过在变量之间添加填充(padding)来分隔缓存行。填充使得每个变量都独立于其他变量,并确保不会与其他变量共享同一缓存行。

以下是一个示例程序,其中使用填充来避免错误共享。

#include 
#include 
#include 

const int kArraySize = 1024;

int main() {
  int array[kArraySize];
  for (int i = 0; i < kArraySize; ++i) {
    array[i] = i;
  }

  int num_threads = 2;
  std::thread threads[num_threads];

  auto start = std::chrono::system_clock::now();

  // spawn threads
  for (int i = 0; i < num_threads; ++i) {
    threads[i] = std::thread([&, i]() {
      // each thread updates every other element
      for (int j = 0; j < kArraySize; ++j) {
        // add padding to avoid false sharing
        int padding[8];
        for (int k = 0; k < 8; ++k) {
          padding[k] = 0;
        }

        if (j % 2 == i) {
          array[j] *= 2;
        }
      }
    });
  }

  // join threads
  for (int i = 0; i < num_threads; ++i) {
    threads[i].join();
  }

  auto end = std::chrono::system_clock::now();
  auto elapsed =
      std::chrono::duration_cast(end - start

相关内容

热门资讯

9分钟指导!小猪对对碰怎么破解... 9分钟指导!小猪对对碰怎么破解(透视)都是真的有挂(2021已更新)(哔哩哔哩)1、小猪对对碰怎么破...
4分钟辅助挂!广东雀神小程序辅... 4分钟辅助挂!广东雀神小程序辅助器最新版(辅助挂)详细辅助插件教程(2020已更新)(今日头条);1...
9分钟内幕!广东雀神外挂真实码... 9分钟内幕!广东雀神外挂真实码(透视)原来真的有挂(2020已更新)(微博客户端)1、用户打开应用后...
一分钟辅助挂!顺欣茶楼可以操控... 一分钟辅助挂!顺欣茶楼可以操控吗(透视)详细辅助插件教程(2022已更新)(百度)一分钟辅助挂!顺欣...
9分钟讲解!乐乐上海麻将攻略(... 9分钟讲解!乐乐上海麻将攻略(辅助挂)果然真的有挂(2021已更新)(今日头条);所有人都在同一条线...
5分钟辅助挂!懒人斗十四有外挂... 5分钟辅助挂!懒人斗十四有外挂吗(透视)详细辅助器教程(2024已更新)(抖音);1、实时懒人斗十四...
三分钟总结!德州竞技联盟辅助(... 三分钟总结!德州竞技联盟辅助(透视)好像真的有挂(2020已更新)(小红书);1、打开软件启动之后找...
十分钟辅助挂!闽南漳州麻将有没... 十分钟辅助挂!闽南漳州麻将有没有挂(辅助挂)详细辅助软件教程(2020已更新)(百度)1、玩家可以在...
9分钟体悟!手机浙江宝宝麻将(... 9分钟体悟!手机浙江宝宝麻将(透视)一般真的有挂(2025已更新)(今日头条)1、手机浙江宝宝麻将a...
五分钟辅助挂!荔枝竞技外挂什么... 五分钟辅助挂!荔枝竞技外挂什么样的(透视)详细辅助插件教程(2023已更新)(微博热搜);1、上手简...