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

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

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

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

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

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

相关推荐
Ulyanov1 小时前
高保真单脉冲雷达导引头回波生成:Python建模与实践
开发语言·python·仿真·系统设计·单脉冲雷达
t***44231 小时前
【Springboot3+vue3】从零到一搭建Springboot3+vue3前后端分离项目之后端环境搭建
java
daidaidaiyu1 小时前
SpringCloud 微服务实现一则 (Eureka + Hystrix)
java·spring
小哥不太逍遥1 小时前
Technical Report 2024
java·服务器·前端
阿猿收手吧!1 小时前
【C++】jthread:优雅终止线程新方案
开发语言·c++
lly2024062 小时前
《JavaScript 实例》
开发语言
edisao2 小时前
序幕-内部审计备忘录
java·jvm·算法
十五年专注C++开发2 小时前
C++中各平台表示Debug的宏
开发语言·c++·debug
shehuiyuelaiyuehao2 小时前
22Java对象的比较
java·python·算法
张小凡vip2 小时前
Python异步编程实战:基于async/await的高并发实现
开发语言·python