【校招VIP】线程同步的机制

08月04日 收藏 0 评论 0 java开发

【校招VIP】线程同步的机制

转载声明:文章来源https://blog.csdn.net/weixin_43591948/article/details/125192478

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

POXIS信号量
互斥量
条件变量

1.信号量

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等待信号量的线程将被唤醒类

2.互斥锁

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

3.条件变量

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

#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)


C 0条回复 评论

帖子还没人回复快来抢沙发