本文主要介绍“什么是java不公平锁”。在日常操作中,相信很多人都对什么是java不公平锁有所怀疑。边肖查阅了各种资料,整理出简单易用的操作方法,希望能帮助大家解答“什么是java不公平锁”的疑惑!接下来,请和边肖一起学习!
1.不公平的锁不能保证锁是按照请求锁的顺序获得的。这可能会导致一个或一些线程永远得不到锁。
2.CPU唤醒线程的成本可以降低,整体吞吐效率会很高。但是,可能会有线程长时间甚至永远得不到锁,从而导致饥饿。
实例
/**
* Syncobjectfornon-fair lock
*/
staticfinalclasofairsyncextendssync {
privatedstationfinalloseriveversiuid=7316153563782823691 l;
/**
*执行扫描。尝试立即插入,恢复正常
*acquireonfailure。
*/
final void lock(){ 0
if(compareAndSetState(0,1))
setExclusiveOwnerThread(thread . currentthread());
其他
获得(1);
}
protected innalbooleantryacquire(intacquires){ 0
returnnonfairTryAcquire(获取);
}
}
/**
* Syncobjectforfairlocks
*/
staticfinaclassfairsynextendssync {
privatedstationfinalloseriveversiuid=nbsp
;-3000897897090466540L;
final void lock() {
acquire(1);
}
/**
* Fair version of tryAcquire. Don't grant access unless
* recursive call or no waiters or is first.
*/
protected final boolean tryAcquire(int acquires) {
final Thread current = Thread.currentThread();
int c = getState();
if (c == 0) {
if (!hasQueuedPredecessors() &&
compareAndSetState(0, acquires)) {
setExclusiveOwnerThread(current);
return true;
}
}
else if (current == getExclusiveOwnerThread()) {
int nextc = c + acquires;
if (nextc < 0)
throw new Error("Maximum lock count exceeded");
setState(nextc);
return true;
}
return false;
}
}
到此,关于“什么是java非公平锁”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/38079.html