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

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

 

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

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

public boolean tryLock() {
        return sync.nonfairTryAcquire(1);
    }

 

 

 

 

 

你可能感兴趣的:(thread,并发,Lock)