我是靠谱客的博主 激昂小鸭子,最近开发中收集的这篇文章主要介绍线程同步的机制,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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

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

最后

以上就是激昂小鸭子为你收集整理的线程同步的机制的全部内容,希望文章能够帮你解决线程同步的机制所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(28)

评论列表共有 0 条评论

立即
投稿
返回
顶部