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

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

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

  • 写回答

1条回答

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

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

    评论

报告相同问题?

悬赏问题

  • ¥15 overleaf中论文编辑,报错`pages' is a missing field, not a string, for entry 4
  • ¥15 vhdl+MODELSIM
  • ¥20 simulink中怎么使用solve函数?
  • ¥30 dspbuilder中使用signalcompiler时报错Error during compilation: Fitter failed,求解决办法
  • ¥15 gwas 分析-数据质控之过滤稀有突变中出现的问题
  • ¥15 没有注册类 (异常来自 HRESULT: 0x80040154 (REGDB_E_CLASSNOTREG))
  • ¥15 知识蒸馏实战博客问题
  • ¥15 用PLC设计纸袋糊底机送料系统
  • ¥15 simulink仿真中dtc控制永磁同步电机如何控制开关频率
  • ¥15 用C语言输入方程怎么