Linux_线程同步_互斥锁

互斥锁(互斥量)pthread_mutex_t

初始化互斥锁:

#include <pthread.h>

int pthread_mutex_init(pthread_mutex_t *restrict mutex, const pthread_mutexattr_t *restrict attr);

attr:设置互斥锁的属性
返回值:成功0,失败错误码
    
可以使用宏PTHREAD+MUTEX_INITIALIZER静态初始化互斥锁:
pthread_mutex_t = PTHREAD+MUTEX_INITIALIZER;
等价于将attr参数设置为NULL,但是PTHREAD+MUTEX_INITIALIZER不进行错误检查。

加锁(置0):

int pthread_mutex_lock(pthread_mutex_t *mutex);

如果互斥锁为0则阻塞,为1则将其值变为0并返回。
返回值:成功0,失败错误码
    
int pthread_mutex_trylock(pthread_mutex_t *mutex);
加锁失败直接返回错误号,不阻塞。

解锁(置1):

int pthread_mutex_unlock(pthread_mutex_t *mutex);

不管值为多少都置1并返回
返回值:成功0,失败错误码

释放互斥锁:

int pthread_mutex_destroy(pthread_mutex_t *mutex);

销毁指定的互斥锁。
返回值:成功0,失败错误码

互斥锁保证锁定的代码只能同时一个线程执行,但不能保证必需执行完!

在lock与unlock之间调用pthread_exit,或者在线程外部调用pthread_cancel,其他线程被永久死锁。

pthread_cleanup_push {
pthread_cleanup_pop  }
这对函数作用类似于atexit 在退出时调用
注意:
这不是函数,而是宏,必须成对使用

pthread_mutex_t m;
void handle(void *d)
{
    printf("退出后的调用!\n");
    pthread_mutex_unlock(&m);
}
 
void* runodd(void *d)
{
    int i=0;
    for(i=1;;i+=2)
    {
        pthread_cleanup_push(handle,0);
        pthread_mutex_lock(&m);
        printf("%d\n",i);
        pthread_cleanup_pop(1);
    }
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值