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

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

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

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

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

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

相关推荐
南境十里·墨染春水1 分钟前
linux学习进展 线程同步——条件变量
java·开发语言·学习
sghuter4 分钟前
数字资源分发的技术架构与未来趋势
c语言·开发语言·后端·青少年编程
窥视未来8 分钟前
MySQL 性能调优完全指南:从硬件到 SQL,一篇吃透
java·数据库
普修罗双战士12 分钟前
【开发工具IDEA调试,高频使用, IntelliJ IDEA 调试快捷键完全指南】
java·开发语言·intellij-idea
海参崴-19 分钟前
C++ 进阶篇 STL 模拟实现二叉搜索树
开发语言·c++
Sakuyu4346823 分钟前
C语言基础(三)
c语言·开发语言
郝学胜-神的一滴26 分钟前
深入epoll反应堆模型:从libevent源码看高性能IO设计精髓
linux·服务器·开发语言·c++·网络协议·unix·信息与通信
XS03010628 分钟前
Java 基础(十)异常
java·开发语言·oracle
和小潘一起学AI28 分钟前
Python导入私有模块(企业级方案)
开发语言·python
_F_y29 分钟前
C++11 异步操作实现线程池
java·jvm·c++