【网路编程】多线程编程--线程同步


  和多进程编程一样,多线程程序也需要考虑到同步问题。pthread_join可以看作是一种简单的线程同步方式,但是它无法实现复杂的同步需求。本章主要讨论三种线程同步方式:

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

一、POSIX信号量

  POSIX信号量函数的名字都以sem_开头,常用的POSIX信号量函数是下面5个,这5个函数成功时返回0,失败返回-1并设置errno:

#include <semaphore.h>
int sem_init(sem_t* sem, int pshared, unsigned int value);
int sem_destory(sem_t* sem);
int sem_wait(sem_t* sem);
int sem_trywait(sem_t* sem);
int sem_post(sem_t* sem);
  • sem_init用于初始化一个未命名的信号量,pshared指定信号量的类型。如果pshared为0,表示这个信号量是当前进程的局部信号量,否则该信号量就可以在多个进程之间共享。value指定信号量的初始值。此外,不要用于初始化一个以及被初始化的信号量。
  • sem_destory用于销毁信号量,释放其占用的内核资源,但不可用于销毁一个被其他线程等待的信号量。
  • sem_wait以原子操作的方式将信号量的值减1,如果信号量为0,则sem_wait阻塞直到信号量具有非0值。
  • sem_trywait相当于sem_wait的非阻塞版本,它始终立即返回不论被操作的信号量是否具有非0值
  • sem_post以原子操作的方式将信号量加1,信号量大于0时,其他正在调用sem_wait等待信号量的线程将被唤醒。

二、互斥锁

  互斥锁相关函数主要有以下5个,具体的函数以及参数解释在P276:

#include <pthread.h>
int pthread_mutex_init(pthread_mutex_t* mutex, const pthread_mutexattr_t* mutexattr);
int pthread_mutex_destory(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);

  上面这些函数成功时返回0,失败时返回错误码。

  pthread_mutexattr_t结构体定义了一套完整的互斥锁属性,下面这些函数是用来操作pthread_mutexattr_t类型的变量:

#include <pthread.h>
/*初始化互斥锁属性对象*/
int pthread_mutexattr_init(pthread_mutexattr_t* attr);
/*销毁互斥锁属性对象*/
int pthread_mutexattr_destory(pthread_mutexattr_t* attr);
/*获取和设置互斥锁的pshared属性*/
int pthread_mutexattr_getpshared(const pthread_mutexattr_t* attr, int* pshared);
int pthread_mutexattr_setpshared(pthread_mutexattr_t* attr, int pshared);
/*获取和设置互斥锁的type属性*/
int pthread_mutexattr_gettype(const pthread_mutexattr_t* attr, int* type);
int pthread_mutexattr_settype(pthread_mutex_attr_t* attr, int type);

三、条件变量

  条件变量提供了一种线程间的通知机制:当某个共享数据达到某个值的时候,唤醒等待这个共享数据的线程,条件变量的相关函数如下:

#include <pthread.h>
int pthread_cond_init(pthread_cond_t* cond, const pthread_condattr_t* cond_attr);
int pthread_cond_destory(pthread_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);

《Linux高性能服务器编程》学习笔记

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Rockict_z

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值