信号量可能允许多个持有者,而自旋锁在任何时候只能允许一个持有者,当然信号量也有一个持有者的(就是互斥锁),允许多个持有者的是计数信号量。
信号量适合保持时间较长的情况,而自旋锁适合于保持时间较短的,
自旋锁不会引起调用者睡眠,如果自旋锁已经被别的执行单元保持,调用者就一直循环在那里看是否该自旋锁的保持者已经释放了锁,"自旋"因此而得名. (自旋锁不会睡眠,只会在那里不停的循环等待),而信号量则引起调用者睡眠,它把进程从运行队列上拖出去,除非获得锁。
如果代码需要睡眠——这往往是发生在和用户空间同步时——使用信号量是唯一的选择。由于不受睡眠的限制,使用信号量通常来说更加简单一些。如果需要在自旋 锁和信号量中作选择,应该取决于锁被持有的时间长短。理想情况是所有的锁都应该尽可能短的被持有,但是如果锁的持有时间较长的话,使用信号量是更好的选 择。另外,信号量不同于自旋锁,它不会关闭内核抢占,所以持有信号量的代码可以被抢占。这意味者信号量不会对影响调度反应时间带来负面影响。
------------------------------------------------------
需求 建议的加锁方法
低开销加锁 优先使用自旋锁
短期锁定 优先使用自旋锁
中断上下文中加锁 使用自旋锁
长期加锁 优先使用信号量
持有锁是需要睡眠、调度 使用信号量