正版马甲 2016-04-22 02:08 采纳率: 0%
浏览 2248

多线程并行计算中的数据竞争问题

我最近搞了一些并行计算方面的算例,有个问题不太明白。
1、对于大型数组变量,只读不写,变量作用域默认共享,在多线程并行计算的时候会不会有数据竞争的问题?
2、如果我把变量名设为私有,那么是不是每个线程只有数组头地址的副本?而数组元素仍为共享,这时候是否还存在数据竞争的问题?
3、如果有写操作时,只将数组变量名设为私有,又会有竞争吗?

  • 写回答

1条回答

  • oyljerry 2016-04-22 03:23
    关注

    1.只读,不会有竞争
    2.私有变量在各自线程空间,栈上数据,不会有竞争
    3.只要有共享数据的写,就会有竞争

    评论

报告相同问题?

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog