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

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

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

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

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

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

相关推荐
用户35218024547512 小时前
当 Prompt 学会"热更新":Spring Boot × Nacos3 AI 实战
java·spring boot·ai编程
东坡白菜15 小时前
破局全栈:一个前端开发的Java入门实战记录(1)
java·全栈
唐青枫16 小时前
Java Tomcat 实战指南:从 Servlet 容器到 Spring Boot 部署
java
wsaaaqqq16 小时前
roudan:自由选择实体、灵活操作数据、快速写入数据库的 Java 框架
java
plainGeekDev20 小时前
null 判断 → Kotlin 可空类型
android·java·kotlin
糖拌西瓜皮20 小时前
Java开发者视角:深入理解Node.js异步编程模型
java·后端·node.js
plainGeekDev20 小时前
getter/setter → Kotlin 属性
android·java·kotlin
一线大码20 小时前
Smart-Doc 的简单使用
java·后端·restful
MacroZheng21 小时前
Claude Code官方桌面端正式发布,夯爆了!
java·人工智能·后端