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
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
相关文章推荐
- 线程池--jetty中QueuedThreadPool分析(一)
- quick 3.3final 编译成功 运行出错的问题
- 关于研究UIautomator操作手机执行case
- OPEN(SAP) UI5 学习入门系列之二: 最佳实践练习(上)
- 使用Hibernate SQLQuery执行原生SQL
- PHP中include和require的区别详解
- 反射(Reflection)的SetValue遇上DBNULL转换为string
- android 开源组件合集-UI篇(2014-08-25更新)
- hdu 5147 Sequence II(前缀和,后缀和)
- The Unique MST (判断是否存在多个最小生成树)
- Flex与服务器交互之一(URLRequest +URLLoader应用)
- requestWindowFeature()的应用
- iOS-UItableView 多组表格
- 将UE添加到鼠标右键打开
- Hibernate使用Query进行查询
- HDU 1242 Rescue(广搜,优先队列)
- UITableView错误 ‘unable to dequeue a cell with identifier Cell'
- 【工作笔记0008】easyui中datagrid绑定到table的翻页注意事项
- IOS的UINavigationController使用
- iOS编程——通过UUID和KeyChain来代替Mac地址实现iOS设备的唯一标示(OC优化版)