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

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

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

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

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

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

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