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

时间:2022-10-26 17:36:23

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

 

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

 原文http://suo.iteye.com/blog/1335992