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

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

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

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

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

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

相关推荐
皮皮林55111 分钟前
Prometheus+Grafana,打造强大的监控与可视化平台
java
JasmineWr19 分钟前
CompletableFuture相关问题
java·开发语言
零雲21 分钟前
java面试:知道java的反射机制吗
java·开发语言·面试
Jeremy爱编码21 分钟前
实现 Trie (前缀树)
开发语言·c#
laocooon52385788630 分钟前
插入法排序 python
开发语言·python·算法
你的冰西瓜1 小时前
C++中的list容器详解
开发语言·c++·stl·list
java1234_小锋1 小时前
Java进程占用的内存有哪些部分?
java
就不掉头发1 小时前
I/O复用
运维·服务器·c语言·开发语言
sxlishaobin1 小时前
Spring Bean生命周期详解
java·后端·spring
曹牧1 小时前
Java:Assert.isTrue()
java·前端·数据库