参考文档
- https://blog.csdn.net/google19890102/article/details/62047798
- https://blog.csdn.net/tennysonsky/article/details/46494077
互斥锁
互斥锁是通过锁的机制来实现线程间的同步问题。互斥锁的基本流程为:
初始化一个互斥锁:
pthread_mutex_init()
函数
加锁:pthread_mutex_lock()
函数或者pthread_mutex_trylock()
函数
对共享资源的操作
解锁:pthread_mutex_unlock()
函数
注销互斥锁:pthread_mutex_destory()
函数
其中,在加锁过程中,
pthread_mutex_lock()
函数和pthread_mutex_trylock()
函数的过程略有不同:
当使用pthread_mutex_lock()
函数进行加锁时,若此时已经被锁,则尝试加锁的线程会被阻塞,直到互斥锁被其他线程释放,当pthread_mutex_lock()
函数有返回值时,说明加锁成功;
而使用pthread_mutex_trylock()
函数进行加锁时,若此时已经被锁,则会返回EBUSY的错误码。
同时,解锁的过程中,也需要满足两个条件:
解锁前,互斥锁必须处于锁定状态; 必须由加锁的线程进行解锁。
当互斥锁使用完成后,必须进行清除。