java并发编程,lock(),trylock(),lockInterruptibly()的区别

首先lock是一种用于共享变量同步的手段,与synchronized不同,它需要显式的上锁和解锁。

lock提供的api接口中有几个值得注意的地方:

lock优先获取锁,只要拿不到锁就一直在阻塞状态,一直阻塞到获取到锁。

trylock则是就尝试一次,拿到了返回true,没拿到返回false,带时间限制的话拿不到会等一会,超出时间限制还没拿到才会返回false。

lockInterruptibly和lock类似,也是一直尝试获取锁,只要没获取到就一直阻塞,直到获取到锁。但是线程会响应中断命令,如果有其他线程发送了中断(Interrupt)指令,那该线程会中断,放弃获取锁,去throw InterruptedException

相关推荐
幸运小圣几秒前
递归(Recursion)快速上手指南【JS例子】
开发语言·javascript·ecmascript
weixin_515039794 分钟前
互联网大厂面试:程序员二狗的搞笑经历
java·学习·面试·程序员·互联网·技术·故事
宠..10 分钟前
安装 Qt VS Tool 插件
开发语言·qt
q***D44315 分钟前
Navicat 连接 SQL Server 详尽指南
java
a***560615 分钟前
Knife4j文档请求异常(基于SpringBoot3,查找原因并解决)
java·服务器·数据库
f***686015 分钟前
Spring Boot 热部署
java·spring boot·后端
5***262216 分钟前
Spring Boot实现定时任务
java·spring boot·后端
2***d88517 分钟前
springcloud springboot nacos版本对应
java
Y***985117 分钟前
SpringBoot整合Email 邮件发送详解
java·spring boot·后端