求教:OpenMP的flush怎么用?

cls555 2009-05-31 05:54:32
似乎所有共享变量都需要设成flush,才能确保安全?
flush到底在何时用呢?
...全文
582 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
qgdbr08 2009-06-03
  • 打赏
  • 举报
回复
就像我上边举的例子,done为共享变量, 如果在并行区域中需要根据done的值来进行一定的操作,也就是说需要不断的更新done的值,确保每个线程对done值的读取为当前值,这时需要用到flush
fanbin23 2009-06-03
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 cls555 的回复:]
谢谢

是不是每个共享变量都需要设成flush ?
[/Quote]

不见得,barrier, taskwait这类同步directive应该已经包含了flush的功能了。如果两次barrier之间某个线程对共享变量的修改需要被另一个线程看到就要用flush。

flush涉及到了OpenMP memory model的细节,可以参考规范中的说明。1楼举了一个在parallel region中手工做synchronization的例子。不过没事还是尽量不要手工做这类同步,除了错很难被thread checker之类的工具查出来。
qgdbr08 2009-06-03
  • 打赏
  • 举报
回复
你可以看一下MSDN里边的这例子:http://msdn.microsoft.com/zh-cn/library/sz9sd6et(VS.80).aspx
cls555 2009-06-03
  • 打赏
  • 举报
回复
谢谢

是不是每个共享变量都需要设成flush ?
cls555 2009-06-02
  • 打赏
  • 举报
回复
共享变量,什么情况下该用flush,什么情况下不用?
qgdbr08 2009-06-01
  • 打赏
  • 举报
回复
当并行区域里存在一共享变量,并且对其进行修改时,需要用flush更新变量,确保并行的多线程对共享变量的读操作是最新值...

done=0;
#pragma omp flush(done)
if(!done)
{
...
done=1;
}

566

社区成员

发帖
与我相关
我的任务
社区描述
英特尔® 边缘计算,聚焦于边缘计算、AI、IoT等领域,为开发者提供丰富的开发资源、创新技术、解决方案与行业活动。
社区管理员
  • 英特尔技术社区
  • shere_lin
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧