首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >这个程序有什么问题?(OpenMP)如何避免它?

这个程序有什么问题?(OpenMP)如何避免它?
EN

Stack Overflow用户
提问于 2021-11-20 05:22:52
回答 1查看 30关注 0票数 0

以下是我的代码,我想知道为什么会发生“竞态条件”的问题,以及如何解决这个问题?

代码语言:javascript
复制
#include <iostream>

int main(){

    int a = 123;

    #pragma omp parallel num_threads(2)

    {

        int thread_id = omp_get_thread_num();

        int b = (thread_id + 1)*10;

        a += b;

    }

    std::cout << “a = “ << a << “\n”;

return 0;

}
EN

回答 1

Stack Overflow用户

发布于 2021-11-20 09:32:49

当两个或多个线程访问共享数据,并且其中至少有一个线程同时更改其值时,就会出现争用条件。在您的代码中,这一行导致了竞争条件:

代码语言:javascript
复制
a += b;

a是一个共享变量,由两个线程同时更新,因此最终结果可能不正确。请注意,根据所使用的硬件,可能的竞争条件并不一定意味着实际上会发生数据竞争,因此结果可能是正确的,但它是代码中的语义错误。

要修复它,您有两个选择:

  1. 使用原子操作:

代码语言:javascript
复制
#pragma omp atomic
a += b;

  1. 使用减少:

代码语言:javascript
复制
#pragma omp parallel num_threads(2) reduction(+:a)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70043455

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档