openmp 互斥锁 mysql_OpenMP(四)线程同步之互斥锁函数

本文详细介绍了OpenMP中的互斥锁函数,包括omp_init_lock、omp_destroy_lock、omp_set_lock、omp_unset_lock和omp_test_lock,并通过示例展示了如何在C++代码中使用这些函数实现线程同步。此外,还提及了事件同步机制中的nowait、barrier和master等概念。
摘要由CSDN通过智能技术生成

线程同步之互斥锁函数

前文介绍了互斥锁同步的两种方法:atomic和critical,本章介绍OpenMP提供的互斥锁函数。互斥锁函数类似于Windows、Linux下的mutex。

1. 互斥锁函数

函数声明                                                                   功能

void omp_init_lock(omp_lock*)                               初始化互斥器

void omp_destroy_lock(omp_lock*)                        销毁互斥器

void omp_set_lock(omp_lock*)                               获得互斥器

void omp_unset_lock(omp_lock*)                           释放互斥器

void omp_test_lock(omp_lock*)                              试图获得互斥器,如果获得成功则返回true,否则返回false

2. 互斥锁示例

·········10········20········30········40········50········60········70········80········90········100·······110·······120·······130·······140·······150

#include 

#include 

static omp_lock_t lock;

int main()

{

omp_init_lock(&lock); //初始化互斥锁

#pragma omp parallel for

for(int i = 0; i 

{

omp_set_lock(&lock);   //获得互斥器

std::cout <

std::cout <

omp_unset_lock(&lock); //释放互斥器

}

omp_destroy_lock(&lock);  //销毁互斥器

return 0;

}

#include

#include

static omp_lock_t lock;

int main()

{

omp_init_lock(&lock); //初始化互斥锁

#pragma omp parallel for

for(int i = 0; i < 5; ++i)

{

omp_set_lock

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值