社区
英特尔边缘计算技术
帖子详情
求教:OpenMP的flush怎么用?
cls555
2009-05-31 05:54:32
似乎所有共享变量都需要设成flush,才能确保安全?
flush到底在何时用呢?
...全文
657
6
打赏
收藏
求教:OpenMP的flush怎么用?
似乎所有共享变量都需要设成flush,才能确保安全? flush到底在何时用呢?
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用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;
}
超详细的
OpenMP
并行编程官方指导
超详细的
OpenMP
并行编程官方指导
OpenMP
程序的编译和运行.docx
。。。
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OpenMP
OvO:
OpenMP
与卸载
OvO:
OpenMP
与卸载 ___ (OvO) < . > --"-"--- OvO是针对C ++和Fortran的
OpenMP
卸载测试功能的集合。 让我开始 $ git clone git@github.com:TApplencourt/OvO.git ; cd OvO # Set your env and run $ OMP_TARGET_OFFLOAD=mandatory CXX="g++" CXXFLAGS="-f
openmp
" FC="gfortran" FFLAGS="-f
openmp
"./ovo.sh run $ ./ovo.sh report >> Overall result test_result/1957-04-01_19-02_CDC6600.lanl.gov pass rate(%) test(#) success(#) com
OpenMP
2.5 手册
OpenMP
2.5 手册 官方文档,并行计算,多核编程
英特尔边缘计算技术
567
社区成员
7,024
社区内容
发帖
与我相关
我的任务
英特尔边缘计算技术
英特尔® 边缘计算,聚焦于边缘计算、AI、IoT等领域,为开发者提供丰富的开发资源、创新技术、解决方案与行业活动。
复制链接
扫一扫
分享
社区描述
英特尔® 边缘计算,聚焦于边缘计算、AI、IoT等领域,为开发者提供丰富的开发资源、创新技术、解决方案与行业活动。
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章