首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

java并发编程-AbstractQueuedSynchronizer的tryLock()步骤分析(六)

2012-09-10 
java并发编程--AbstractQueuedSynchronizer的tryLock()方法分析(六)tryLock()仅尝试一次获取锁,不管成功与

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

tryLock()仅尝试一次获取锁,不管成功与否,都将返回结果。

?

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

?

?

?

?

?

热点排行