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

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

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

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

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

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

相关推荐
我命由我12345几秒前
Windows 操作系统 - Windows 查看防火墙是否开启、Windows 查看防火墙放行端口
java·运维·开发语言·windows·java-ee·操作系统·运维开发
fly spider1 分钟前
Spring 原理总览:从启动到请求执行
java·数据库·spring
天天进步20153 分钟前
Python全栈项目--基于Python的数据库管理工具
开发语言·数据库·python
YHHLAI4 分钟前
JavaScript 数据结构精讲:数组底层与实战避坑
开发语言·javascript·数据结构
有点。5 分钟前
C++贪心算法一(练习题)
开发语言·c++·贪心算法
xinhuanjieyi12 分钟前
Android 画板应用kotlin实现
android·开发语言·kotlin
threelab16 分钟前
Three.js 几何图形变换 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
大大杰哥16 分钟前
SSeEmitter的基本使用和介绍
java·sse·通信
闪电悠米18 分钟前
黑马点评-Redis 消息队列-02_list_pubsub_limits
java·数据库·ide·redis·缓存·list·intellij-idea
无限进步_19 分钟前
Linux进程等待——wait、waitpid与僵尸进程
linux·运维·服务器·开发语言