互斥锁
Linux中提供一把互斥锁mutex(也称之为互斥量)。每个线程在对资源操作前都尝试先加锁,成功加锁才能操作,操作结束解锁。
资源还是共享的,线程间也还是竞争的,但通过“锁”就将资源的访问变成互斥操作,而后与时间有关的错误也不会再产生了。
主要相关函数
-
pthread_mutex_t 类型
其本质是一个结构体,为简化理解,应用时可忽略其实现细节,简单当成整数看待。
pthread_mutex_t mutex; 变量mutex只有两种取值1、0。 -
pthread_mutex_init函数
函数描述:
初始化一个互斥锁(互斥量)---->初值可看作1
函数原型:
int pthread_mutex_init(pthread_mutex_t *restrict mutex,const pthread_mutexattr_t *restrict attr);
函数参数:
mutex:传出参数,调用时应传&mutex;
attr:互斥锁属性。是一个传入参数,通常传NULL,选用默认属性(线程间共享)。 -
pthread_mutex_destroy()函数
函数描述:
销毁一个锁;
函数原型:
int pthread_mutex_destroy(pthread_mutex_t *mutex);
函数参数:
mutex-- 互斥锁变量 -
pthread_mutex_lock()函数
函数描述:
对互斥锁加锁,可以理解为 mutex- -;
函数原型:
int pthread_mutex_lock(pthread_mutex_t* mutex);
函数参数:
mutex-- 互斥锁变量 -
pthread_mutex_unlock()函数
函数描述:
对互斥锁加锁,可以理解为 mutex++;
函数原型:
int pthread_mutex_unlock(pthread_mutex_t* mutex);
函数参数: