非公平锁意味着可以插队。那为什么性能会更好呢?
我们必须先知道,在恢复一个被挂起的线程与该线程真正开始运行之间存在着严重的延迟。
举个例子,a线程获取到了锁,现在b线程来请求锁。a线程释放锁唤醒b线程。b线程恢复运行状态。这里需要时间。如果允许插队,c线程刚刚好在a释放前请求锁。可能在c释放完锁后。b线程才真正开始运行起来。
其实就是说切换上下文的开销是比较大的。有时候我们可以用短时间的轮询获取锁会更快。
非公平锁意味着可以插队。那为什么性能会更好呢?
我们必须先知道,在恢复一个被挂起的线程与该线程真正开始运行之间存在着严重的延迟。
举个例子,a线程获取到了锁,现在b线程来请求锁。a线程释放锁唤醒b线程。b线程恢复运行状态。这里需要时间。如果允许插队,c线程刚刚好在a释放前请求锁。可能在c释放完锁后。b线程才真正开始运行起来。
其实就是说切换上下文的开销是比较大的。有时候我们可以用短时间的轮询获取锁会更快。