1.互斥量mutex
原理:在访问共享资源前对互斥量进行加锁,在访问完成后释放互斥量上的锁,任何其它试图再次对互斥量加锁的线程将会阻塞直到当前线程释放该互斥锁。(简单理解:加锁 解锁)
2.互斥量mutex 和 条件变量
原理:利用线程间共享的全局变量进行同步的一种机制,主要包括两个动作:一个线程等待“条件变量的条件成立”而挂起;另一个线程使“条件成立”而发出信号。(多线程中用来实现等待--》唤醒”逻辑的常用的方法)
3.区别
①互斥锁可能会造成死锁,条件变量和互斥锁联用可以避免此问题,条件变量通过允许线程阻塞和等待另一个线程发送信号的方法弥补了互斥锁的不足,在条件满足时,自动退出阻塞,再加锁进行操作。
②避免线程不断轮训检查该条件是否成立而降低效率,造成cpu浪费严重,效率低下。
参考:
https://blog.csdn.net/lwz15071387627/article/details/88132835
https://blog.csdn.net/sishuiliunian0710/article/details/9625407