社区
英特尔边缘计算技术
帖子详情
求教:OpenMP的flush怎么用?
cls555
2009-05-31 05:54:32
似乎所有共享变量都需要设成flush,才能确保安全?
flush到底在何时用呢?
...全文
582
6
打赏
收藏
求教:OpenMP的flush怎么用?
似乎所有共享变量都需要设成flush,才能确保安全? flush到底在何时用呢?
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用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;
}
OmpSCR:
OpenMP
Source Code Repository-开源
OmpSCR:
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
API
此文件是关于
OpenMp
的使用手册:
openmP
application interface .
OpenMP
:
OpenMP
任务
#
OpenMP
任务 ##命令编译 ➜ git:(master) ✗ gcc -o omp1 -f
openmp
OpenMP
/omp01.c omp1 - 可执行文件,omp1.c - 要编译的文件 ##命令运行 ➜ git:(主) ✗ ./omp1 omp1 - 可执行文件 设置线程数量 omp_set_num_threads() - 通过 func OMP_NUM_THREADS - 通过全局变量。 Habr 的 OMP 教程
OpenMP
:
OpenMP
的实践练习
OpenMP
的实践练习 描述 “并行编程入门”课程的实际任务解决方案 主导课程: 用法 但是,所有示例都是一个文件。 用于编译C程序 gcc file_name.c -f
openmp
-std=c99 对于运行程序,您需要使用C语言standart c99或更高版本。 对于编译的C ++程序,请运行 g++ file_name.cpp -f
openmp
使用gcc标志-o设置执行文件的名称
英特尔边缘计算技术
566
社区成员
7,027
社区内容
发帖
与我相关
我的任务
英特尔边缘计算技术
英特尔® 边缘计算,聚焦于边缘计算、AI、IoT等领域,为开发者提供丰富的开发资源、创新技术、解决方案与行业活动。
复制链接
扫一扫
分享
社区描述
英特尔® 边缘计算,聚焦于边缘计算、AI、IoT等领域,为开发者提供丰富的开发资源、创新技术、解决方案与行业活动。
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章