互斥锁保证每时刻每个用户看到的共享数据是一样的。只有lock与unlock两种状态,确保同一时间只有一个线程访问数据。
在同一时间通常只允许一个线程执行部分代码。
使用互斥锁前必须进行初始化操作。
(1)pthread_mutex_t = PTHREAD_MUTEX_INITIALIZER;
(2)int pthread_mutex_init (pthread_mutex_t *mutex, const pthread_mutexattr_t *mutexattr);
互斥锁锁住的并不是一个变量,而是阻塞一段程序。如果对一个mutex变量执行了第一次lock之后,在unlock前的这短时间内,如果有其他线程也只行到了lock,这个线程就会阻塞住,知道之前的lock解锁之后才能执行。
加锁:
int pthread_mutex_lock(pthread_mutex_t *mutex);
int pyhread_mutex_trylock(pthread_mutex_t *mutex);
若mutex已经被加锁则lock会等带其解锁再加锁运行后面的程序,而trylock若遇到mutex以加锁则立即返回返回的错误代码为EBUSY,而不是阻塞等待。
解锁:
int pthread_mutex_unlock(pthread_mutex_t *mutex);
解锁时需要满足两个条件,一时互斥锁处于加锁状态,二是调用unlock的线程必须是给互斥锁加锁的线程;
int pthread_thread_delete(pthread_mutex_destory);
清楚一个互斥锁意味着释放其占有的资源清除锁时要求当前处于开放状态。