您的位置:首页 > 产品设计 > UI/UE

java并发编程--AbstractQueuedSynchronizer的tryLock()方法分析(六)

2015-08-13 11:28 686 查看
tryLock()仅尝试一次获取锁,不管成功与否,都将返回结果。

Java代码


public boolean tryLock()仅在调用时锁未被另一个线程保持的情况下,才获取该锁。

如果该锁没有被另一个线程保持,并且立即返回 true 值,则将锁的保持计数设置为 1。即使已将此锁设置为使用公平排序策略,但是调用 tryLock() 仍将 立即获取锁(如果有可用的),而不管其他线程当前是否正在等待该锁。在某些情况下,此“闯入”行为可能很有用,即使它会打破公平性也如此。如果希望遵守此锁的公平设置,则使用 tryLock(0, TimeUnit.SECONDS) ,它几乎是等效的(也检测中断)。

如果当前线程已经保持此锁,则将保持计数加 1,该方法将返回 true。

如果锁被另一个线程保持,则此方法将立即返回 false 值。

Java代码


返回: 如果锁是自由的并且被当前线程获取,或者当前线程已经保持该锁,则返回 true;否则返回 false

public boolean tryLock() {

return sync.nonfairTryAcquire(1);

}

原文http://suo.iteye.com/blog/1335992
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: