求教:OpenMP的flush怎么用?

cls555 2009-05-31 05:54:32
似乎所有共享变量都需要设成flush,才能确保安全?
flush到底在何时用呢?
...全文
654 6 打赏 收藏 转发到动态 举报
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;
}
内容概要:本文档是2025年全国广播电视技术能手竞赛IPTV专业的竞赛内容大纲,旨在指导参赛选手准备比赛。竞赛分为理论和实操两大部分。理论部分涵盖基本知识、基础理论和专业知识,包括法律法规、技术标准、IPTV技术基础、信号传输与分发、网络和数据安全等。实操部分则涉及IPTV系统设备、仪器设备的操作使用和指标测量。具体内容包括IPTV系统架构、传输技术与指标、设备配置及维护、专业技能如测量工具使用、视音频指标测量、直播点播协议分析、播出网络性能测量、网络安全数据分析以及系统故障排查等。 适合人群:从事或有意从事IPTV相关工作的技术人员,尤其是有志于参加全国广播电视技术能手竞赛的专业人士。 使用场景及目标:①帮助参赛选手全面了解并掌握IPTV相关的法规文件和技术标准;②提升选手对IPTV系统架构、传输技术和设备配置的理解;③增强选手在实际操作中的测量、分析和故障排查能力;④确保选手能够熟练运用各种测量工具和分析软件进行视音频指标测量和网络安全数据分析。 阅读建议:由于文档内容详尽且专业性强,建议读者在学习过程中结合实际案例和操作练习,同时参考相关技术文献,以便更好地理解和掌握竞赛所需的知识和技能。

567

社区成员

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

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