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

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

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

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

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

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

相关推荐
爱吃大芒果1 分钟前
Flutter 网络请求完全指南:Dio 封装与拦截器实战
开发语言·javascript·flutter·华为·harmonyos
云水木石1 分钟前
Rust 语言开发的 Linux 桌面来了
linux·运维·开发语言·后端·rust
要开心吖ZSH8 分钟前
应用集成平台-系统之间的桥梁-思路分享
java·kafka·交互
TsengOnce11 分钟前
阿里云ECS多版本JDK切换
java·python·阿里云
wearegogog12314 分钟前
基于C#的FTP客户端实现方案
java·网络·c#
听风吟丶15 分钟前
Java NIO 深度解析:从核心组件到高并发实战
java·开发语言·jvm
野生技术架构师22 分钟前
Java面试题及答案总结(互联网大厂新版)
java·面试·状态模式
a努力。23 分钟前
小红书Java面试被问:ThreadLocal 内存泄漏问题及解决方案
java·jvm·后端·算法·面试·架构
此生只爱蛋23 分钟前
【Redis】String 字符串
java·数据库·redis
C++业余爱好者24 分钟前
Java开发中Entity、VO、DTO、Form对象详解
java·开发语言