概述
三种专门用于线程同步的机制
- 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)
最后
以上就是激昂小鸭子为你收集整理的线程同步的机制的全部内容,希望文章能够帮你解决线程同步的机制所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复