锁的释放流程-unparkSuccessor
生活随笔
收集整理的這篇文章主要介紹了
锁的释放流程-unparkSuccessor
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
private void unparkSuccessor(Node node) { int ws = node.waitStatus;//獲得head節(jié)點的狀態(tài) if (ws < 0) compareAndSetWaitStatus(node, ws, 0);// 設(shè)置head節(jié)點狀態(tài)為0 Node s = node.next;//得到head節(jié)點的下一個節(jié)點 if (s == null || s.waitStatus > 0) { //如果下一個節(jié)點為null或者status>0表示cancelled狀態(tài). //通過從尾部節(jié)點開始掃描,找到距離head最近的一個waitStatus<=0的節(jié)點 s = null; for (Node t = tail; t != null && t != node; t = t.prev) if (t.waitStatus <= 0) s = t; } if (s != null) //next節(jié)點不為空,直接喚醒這個線程即可 LockSupport.unpark(s.thread);
}
?
總結(jié)
以上是生活随笔為你收集整理的锁的释放流程-unparkSuccessor的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 锁的释放流程-ReentrantLock
- 下一篇: 为什么在释放锁的时候是从 tail 进行