本篇内容介绍了“AbstractQueuedSynchronizer是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
AbstractQueuedSynchronizer抽象类
子类中独自实现以下方法
* <li> {@link #tryAcquire} * <li> {@link #tryRelease} * <li> {@link #tryAcquireShared} * <li> {@link #tryReleaseShared} * <li> {@link #isHeldExclusively}
state状态修改使用以下方法
{@link #getState}, {@link * #setState} {@link #compareAndSetState}:
Node{
// 表示节点状态,CANCELLED,值为1 ,表示当前线程被取消 SIGNAL 值为-1,
//表示当前节点的后继节点包含的线程需要运行,也就是unpark
// condition 值为-2 ,表示当前节点在等condition,也就是condition队列中
// propagate,值为-3 ,表示当前场景下后续的acquireShared能够得以执行;
//值为0,表示当前节点在sync队列中,等待着获取锁
int waitStatus;
// 前驱节点,如取消当前节点,就需要完成连接
Node prev;
//后继节点
Node next;
//存储condition队列中的后继节点
Node nextWaiter;
//入队列当前线程
Thread thread;
}
//获取一个排他锁
while(获取锁){
if(获取到){
退出while循环
} else {
if(当前线程没有入队列){
那么入队列
}
阻塞当前线程
}
}
}
}
// 释放一个排他锁
if(释放成功){
删除头节点
激活原头结点的后继节点
}
“AbstractQueuedSynchronizer是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。