线程同步的机制

三种专门用于线程同步的机制

  • POXIS信号量
  • 互斥量
  • 条件变量

信号量

int sem_init(sem_t* sem,int pshared,unsigned int value);
int sem_destroy(sem_t*sem)
int sem_wait(sem_t*sem)
int sem_try_wait(sem_t*sem);
int sem_post(sem_t*sem) 
sem_init初始化一个未命名的信号量,如果pshared=0表示为当前进程的局部变量,否则是多个进程共享
sem_destroy用于销毁信号量
sem_wait以原子操作的方式将信号量的值减一,如果信号量的值为0,则sem_wait将被拥塞,直到这个信号具有非0值
sem_try_wait函数与sem_wait相似,不过它始终立即返回,无论被操作的信号量是否非0,如相当于sem_wait的非拥塞版本。当信号量为0时,对其进行-1操作,如果信号量为0,就返回-1并设置errno为EAGAIN
sem_post函数以原子操作的方式将信号量+1,当信号量的值大于0时,其正在调用sem_wait等待信号量的线程将被唤醒类

互斥锁

int pthread_mutex_init(pthread_mutex_t*mutex,const pthread_attr_t*mutex_attr)
int pthread_mutex_destroy(pthread_mutex_t*mutex)
int pthread_mutex_lock(pthread_mutex_t*mutex)
int pthread_mutex_trylock(pthread_mutex_t*mutex)
int pthread_mutex_unlock(pthread_mutex_t*mutex)
pthread_mutex_init初始化互斥锁
pthread_mutex_destroy用于销毁互斥锁,以释放其内核资源。销毁一个已经加锁的互斥锁将导致不可预期的后果
pthread_mutex_lock以原子形式给互斥锁加锁,如果目标互斥锁已经被锁上,则调用将拥塞,直到该互斥锁的占有者将其解锁
pthread_mutex_trylock如果目标互斥锁没有被上锁,对其进行上锁,否则返回错误码EBUSY

条件变量
功能:当某个数据到达某个值的时候,唤醒等待在这个共享数据的线程

#include<pthread.h>
int pthread_cond_init(pthread_cond_t cond,const pthread_condattr_t*cond_attr)
int pthread_cond_destroy(phthread_cond_t cond)
int pthread_cond_broadcast(pthread_cond_t cond)
int pthread_cond_signal(pthread_cond_t cond)
int pthread_cond_wait(pthread_cond_t cond,pthread_mutex_t*mutex)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值