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

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

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

  • 写回答

1条回答 默认 最新

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

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

    评论

报告相同问题?

悬赏问题

  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题