当前位置: 首页 > news >正文

ReentrantLock

与 synchronized的异同点:

相同:都支持可重入

可重入:可重入是指同一个线程如果首次获得了这把锁,那么因为它是这把锁的拥有者,因此有权利再次获取这把锁 如果是不可重入锁,那么第二次获得锁时,自己也会被锁挡住

@Slf4j(topic = "c.TestReentrant")
public class TestReentrant {static ReentrantLock lock = new ReentrantLock();public static void main(String[] args) {method1();}public static void method1() {lock.lock();try {log.debug("execute method1");method2();} finally {lock.unlock();}}public static void method2() {lock.lock();try {log.debug("execute method2");method3();} finally {lock.unlock();}}public static void method3() {lock.lock();try {log.debug("execute method3");} finally {lock.unlock();}}
}

不同:对于 synchronized它具备如下特点

可中断
可以设置超时时间
可以设置为公平锁

公平锁一般没有必要,会降低并发度;可以使用tryLock()去设置超时时间。

支持多个条件变量

送烟、送外卖的例子;

多个条件变量,对应多个等待区;

http://www.dtcms.com/a/169921.html

相关文章:

  • Spring 事务的底层原理常见陷阱
  • 《解锁Windows下GCC升级密码,开启高效编程新旅程》
  • # LeetCode 1007 行相等的最少多米诺旋转
  • FreeRTOS事件组的本质
  • Flink 的状态机制
  • DeepSeek实战--LLM微调
  • 【算法基础】递归算法 - JAVA
  • 《Java高级编程:从原理到实战 - 进阶知识篇四》
  • 【c语言】数据在内存中的存储
  • [Linux开发工具]gcc/g++
  • wpf CommandParameter 传递MouseWheelEventArgs参数
  • [Vue]编程式导航
  • 回溯算法详解(Java实现):从组合到排列的全面解析
  • 延时启动windows中程序
  • MARM:推荐系统中的记忆增强突破
  • Cycleresearcher:通过自动化评审改进自动化研究
  • C# 方法(控制流和方法调用)
  • SQL笔记——左连接、右连接、内连接
  • pip命令
  • #Paper Reading# DeepSeek-R1
  • 在 Trae CN IDE 中配置 Python 3.11的指南
  • 修改ollama.service都可以实现什么?
  • 【网络编程】HTTP(超文本传输协议)详解
  • 头歌数据库课程实验(索引与数据库完整性)
  • 计算方法实验五 插值多项式的求法
  • AI超级智能体教程(五)---自定义advisor扩展+结构化json输出
  • FreeRtos实战从入门到精通--任务创建和删除(动态方法)--事了拂衣去,深藏功与名
  • 先知AIGC超级工场,撬动运营效率新杠杆
  • ASP.NET MVC​ 入门与提高指南八
  • (超2万字数详解)C++学习之类与对象