为了避免并发,防止竞争.内核提供了一组同步方法来提供对共享数据的保护. 我们的重点不是介绍这些方法的详细用法,而是强调为什么使用这些方法和它们之间的差别. Linux 使用的同步机制可以说从2.0到2.6以来不断发展完善.从最初的原子操作,到后来的信号量,从大内核锁到今天的自旋锁.这些同步机制的发展伴随 Linux从单处理器到对称多处理器的过度:伴随着从非抢占内核到抢占内核的过度.锁机制越来越有效,也越来越复杂.目前来说内核中原子操作多用来做计数使用,其它情况最常用的是两种锁以及它们的变种:一个…