本文,记录Linux-pthread-lock-mechanism(锁机制)。
<精髓>6.8Linux内核并发机制 202页,讲述非常清晰,带内核API表单
其实,起草本文的时候,我是压根不知道写什么的,后来发现,可以解决
- Linux各种锁的实现原理
- Linux底层锁的实现代码
操作系统课程里面,锁机制,两个操作称为:PV操作
什么是PV操作,
链接
- P是加锁
- V是释放
Linux底层(操作系统实现),锁的实现机制是
- 原子操作
- 自旋锁
- 信号量(Linux底层提供了多个种类的信号量)
- 二值信号量——理解为互斥量
- 计数信号量——理解为信号量
- 读写信号量——理解为读写锁
Linux应用层,锁的接口有
- 互斥量
- 条件变量
最基本的两个锁,而且也是最常用的,大部分应用程序,你只需要使用这两个锁即可完成任务。
当然了,还有一些根据功能/应用的特性来实现特殊的锁的应用接口。
- 读写锁——适应读操作非常多的应用
- 自旋锁——避免互斥量将线程投入睡眠
- 屏障——协同多个线程进行操作,如:大数据排序
Linux应用层,使用锁的时候,会将线程投入睡眠,以便资源满足的情况下,重新调用执行。
- 互斥量
- 条件变量
- 读写锁
- 屏障
唯独——自旋锁,不会投入睡眠,这也就是它的特性,适应短暂停留的应用里面。