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

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

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

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

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

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

相关推荐
极客BIM工作室2 分钟前
C++ 限制类对象数量的技巧与实践
开发语言·javascript·c++
会是上一次20 分钟前
企业级WEB应用服务器TOMCAT
java·前端·tomcat
Java中文社群1 小时前
抱歉!Java面试标准答案最不重要
java·后端·面试
wjs20242 小时前
C++ 日期 & 时间
开发语言
终焉代码2 小时前
【C++】STL二叉搜索树——map与set容器的基础结构
开发语言·数据结构·c++
源代码•宸2 小时前
深入浅出设计模式——行为型模式之观察者模式 Observer
开发语言·c++·经验分享·观察者模式·设计模式·raii
Java小Y2 小时前
redis(2)-java客户端使用(IDEA基于springboot)
java·redis·intellij-idea
herderl2 小时前
【无标题】命名管道(Named Pipe)是一种在操作系统中用于**进程间通信(IPC)** 的机制
java·linux·服务器·嵌入式硬件·php
小五1272 小时前
数据科学与计算实例应用
开发语言·python