OpenMP 不完全笔记

线程同步 atomic

在OpenMP中,线程同步机制包括互斥锁同步机制和事件同步机制。互斥锁同步的概念类似于Windows中的临界区(CriticalSection)以及Windows和Linux中的Mutex,以及VxWorks中的SemTake何SemGive(初始化时信号量为满),即对某一块代码操作进行保护,以保证同时只能有一个线程执行该段代码。

1 #pragma omp atomic
2 x< + or * or - or * or / or & or | or << or >> >=expr
3 (例如x <<= 1; or x *=2;)
4 
5 6 
7 #pragma omp atomic
8 x++ //or x--, --x, ++x

可以看到atomic的操作仅适用于两种情况:

1. 自加减操作
2. x<上述列出的操作符>=expr


 

线程同步之 critical
这里的临界区与Windows下的CriticalSection类似。

临界区声明方法

1 #pragma omp critical [(name)] //[]表示名字可选
2 {
3 //并行程序块,同时只能有一个线程能访问该并行程序块
4 }

 

posted @ 2020-06-15 19:54  大蓝鲸  阅读(171)  评论(0编辑  收藏  举报