互斥锁----pthread_mutex_t,pthread_mutex_init,pthread_mutex_lock,pthread_mutext_unlock,pthread_mutex_des

本文详细介绍了Posix互斥锁的使用方法,包括初始化、销毁、加锁和解锁等核心操作。阐述了如何根据互斥锁变量的分配方式选择初始化方法,并解释了阻塞加锁与非阻塞加锁的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Posix互斥锁被声明为具有 pthread_mutex_t 数据类型的变量。

如果互斥锁变量是静态分配的,那么可以使用PTHREAD_MUTEX_INITIALIZER来进行初始化。
如果互斥锁变量是动态分配的,那么就应该用pthread_mutex_init来进行初始化。

初始化::
#include <pthread.h>
int pthread_mutex_init(pthread_mutex_t *,pthread_mutexattr_t *); //默认第二个参数是NULL

PTHREAD_MUTEX_INITIALIZER



销毁::
#include <pthread.h>
int pthread_mutex_destroy(pthread_mutex_t *);



互斥锁上锁::
#include <pthread.h>
int pthread_mutex_lock(pthread_mutex_t *);
int pthread_mutex_trylock(pthread_mutex_t *);


互斥锁解锁::
#include <pthread.h>
int prhead_mutex_unlock(pthread_mutex_t *);


阻塞加锁pthread_mutex_lock::
如果尝试给一个已由另外一个线程锁住的互斥锁上锁,那么pthread_mutex_lock将阻塞,直到该互斥锁解锁为止。

非阻塞加锁pthread_mutex_trylock::
如果尝试给一个已由另外一个线程锁住的互斥锁上锁,那么pthread_mutex_trylock将立即返回,并返回错误码在errno中,为EBUSY。

(当有多个线程互斥加锁阻塞在同一个地方时,当锁被释放时,优先释放优先级最高的线程)


尽管我们说互斥锁保护的是临界区,实际上保护的是临界区中被操作的数据(data)。 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值