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

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

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

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

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

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

相关推荐
星光一影22 分钟前
基于PHP+MySQL+Uniapp的上门家政服务系统源码
开发语言·mysql·uni-app·php
Antonio91523 分钟前
【Swift】 UIKit:UIGestureRecognizer和UIView Animation
开发语言·ios·swift
q***017726 分钟前
Spring Boot 热部署
java·spring boot·后端
Seven9727 分钟前
SpringCloud 常见面试题(三)
java
D***t13127 分钟前
PHP在API开发中的框架选择
开发语言·php
H***997628 分钟前
Java虚拟现实案例
java·开发语言·vr
Tan_Ying_Y39 分钟前
synchronized和ReentrantLock的区别是什么?他们的底层原理是什么?
开发语言·c#
ChineHe1 小时前
Golang并发编程篇002_Go并发基础
开发语言·后端·golang
默恋~微凉1 小时前
shell(八)——WEB与Nginx
开发语言·前端·php
yifengyiyufjq1 小时前
Docker 镜像制作教程
java·docker·node.js