27.ReentrantLock

1.与synchronized不同点:

  • 可中断
  • 可以设置超时时间
  • 可以设置公平锁,公平锁就是为了解决饥饿线程,让线程排队,先进先出,先来的线程先执行。
  • 支持多个条件变量

2.与synchronized相同点都支持锁的可重入

基本格式:

//获取锁
reentrantLock.lock();
try {} finally {//必须释放锁reentrantLock.unlock();
}

可重入

同一个线程如果首次获得了这把锁,因为它是这把锁的拥有者,因此有权利再次获取这把锁。

如果是不可重入锁,那么第二次获得锁时,自己也会被锁挡住。

@Slf4j
public class ReentrantLockDemo {private static ReentrantLock reentrantLock = new ReentrantLock();public static void main(String[] args) {//获取锁reentrantLock.lock();try {log.info("调用main方法...");method1();} finally {//必须释放锁reentrantLock.unlock();}}public static void method1() {reentrantLock.lock();try {log.info("调用method1方法...");method2();}finally {reentrantLock.unlock();}}public static void method2() {reentrantLock.lock();try {log.info("调用method2方法...");}finally {reentrantLock.unlock();}}
}

可被中断

lockInterruptibly方法表示可被打断的锁

lokc方法加锁表示不可被打断的锁

可打断的锁,可以防止死锁。

@Slf4j
public class Reen {private static ReentrantLock reentrantLock = new ReentrantLock();public static void main(String[] args) {Thread t1 = new Thread(() -> {try {log.info("尝试获取锁....");//lockInterruptibly可被打断的锁reentrantLock.lockInterruptibly();} catch (InterruptedException e) {e.printStackTrace();log.info("等待获取锁的线程被打断....返回");return;}try {log.info("获取到了锁...");}finally {reentrantLock.unlock();}}, "t1");//main线程获取锁reentrantLock.lock();t1.start();try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}log.info("打断线程t1....");t1.interrupt();}
}

 可以设置超时时间

tryLock方法,设置超时时间,避免长时间等待,防止死锁。

tryLock方法不设置超时时间参数表示获取不到锁立刻返回。

@Slf4j
public class ReenDemo {private static ReentrantLock reentrantLock = new ReentrantLock();public static void main(String[] args) {Thread t1 = new Thread(() -> {//尝试获取锁,时间是立刻返回log.info("尝试获取锁...");try {if(!reentrantLock.tryLock(2, TimeUnit.SECONDS)) {log.info("尝试获取锁失败,返回...");return;}log.info("尝试获取锁成功...");} catch (InterruptedException e) {e.printStackTrace();log.info("尝试获取锁被打断,返回...");return;}try {}finally {reentrantLock.unlock();}}, "t1");reentrantLock.lock();t1.start();try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}try {}finally {reentrantLock.unlock();}}
}

解决哲学家吃饭的死锁问题:

public class DeadLockDemo {public static void main(String[] args) {Chopstick chopstick1 = new Chopstick("1");Chopstick chopstick2 = new Chopstick("2");Chopstick chopstick3 = new Chopstick("3");Chopstick chopstick4 = new Chopstick("4");Chopstick chopstick5 = new Chopstick("5");new Philosopher("哲学家1", chopstick1, chopstick2).start();new Philosopher("哲学家2", chopstick2, chopstick3).start();new Philosopher("哲学家3", chopstick3, chopstick4).start();new Philosopher("哲学家4", chopstick4, chopstick5).start();new Philosopher("哲学家5", chopstick5, chopstick1).start();}
}@Slf4j
class Philosopher extends Thread {//左边的筷子Chopstick left;//右边的筷子Chopstick right;public Philosopher(String name, Chopstick left, Chopstick right) {super(name);//设置线程名称this.left = left;this.right = right;}@Overridepublic void run() {while (true) {//这里意思是一位哲学家获取了两根筷子后吃完饭,又重新开始下一轮...//解决死锁问题,使用ReentrantLock.tryLock方法,避免长时间等待不释放锁的情况if(left.tryLock()) {try {if(right.tryLock()) {try {eat();}finally {right.unlock();}}}finally {left.unlock();}}//            synchronized (left) {
//                synchronized (right) {
//                    eat();
//                }
//            }}}private void eat() {log.info("eat...");try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}}
}/*** 筷子类*/
class Chopstick extends ReentrantLock{//名称private String name;public Chopstick(String name) {this.name = name;}@Overridepublic String toString() {return "Chopstick{" +"name='" + name + '\'' +'}';}
}

公平锁

ReentrantLock模式是非公平锁,synchronized也是非公平锁。但是ReentrantLock可以设置为公平锁。new ReentrantLock(true); 公平锁可以防止饥饿锁。按照先进先出的规则。公平锁会降低并发度。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/788742.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JavaScript 超详细学习思路

JavaScript 是一种轻量级的编程语言,它可以在网页中嵌入,用来实现网页的动态效果和用户交互功能。它是 Web 开发中不可或缺的一部分,与 HTML 和 CSS 并称为 Web 技术的三大基石。下面我会根据您的要求,对每个部分进行详细的讲解。…

“崖山数据库杯”深圳大学程序设计竞赛(正式赛)M题 一图秒

“崖山数据库杯”深圳大学程序设计竞赛(正式赛)_ACM/NOI/CSP/CCPC/ICPC算法编程高难度练习赛_牛客竞赛OJ (nowcoder.com) —————— 可以去牛客看题解: 题解 | #暂时没想法#_牛客博客 (nowcoder.net) —————— 上面的就是题解了。…

Web CSS笔记3

一、边框弧度 使用它你就可以制作盒子边框圆角 border-radius:1个值四个圆角值相同2个值 第一个值为左上角与右下角,第二个值为右上角与左下角3个值第一个值为左上角, 第二个值为右上角和左下角,第三个值为右下角4个值 左上角,右…

大数据时代的生物信息学:挖掘生命数据,揭示生命奥秘

在当今科技日新月异的时代,大数据如同一座蕴藏无尽宝藏的矿山,而生物信息学则是那把锐利的探矿锤,精准有力地敲击着这座“生命之矿”,揭示出隐藏在其深处的生命奥秘。随着基因测序技术的飞速进步与广泛应用,生物医学领…

springboot之MybatisPlus

文章目录 一、ORM二、mybatis实际操作三、mybatis-plus 一、ORM 简单来说ORM就是一个能够帮我们把java中Bean类映射到数据库中。 使用mybatis-plus。 配置架包 <!-- MyBatisPlus依赖 --><dependency><groupId>com.baomidou</groupId><art…

垄断与商品化背景下的网络安全三大整合策略

我国的网络安全产业已经发展了20余年&#xff0c;大大小小的企业几乎覆盖了网络安全的所有领域。随着安全需求的逐渐递增&#xff0c;安全产品也朝着平台化、规模化发展&#xff0c;这就倒逼着安全厂商需要整合越来越多的安全能力&#xff0c;并与其产品相融合。这个过程&#…

安装transforers时报错:error: can‘t find Rust compiler

报错&#xff1a; error: cant find Rust compilerIf you are using an outdated pip version, it is possible a prebuilt wheel is available for this package but pip is not able to install from it. Installing from the wheel would avoid the need for a Rust compil…

【VSCode+Keil5+STM32CubeMX】开发环境配置

一、软件下载 二、软件安装 三、配置环境 四、验证开发环境 五、Keil与VS Code的同步 从0到1搭建VS Code Keil5 STM32CubeMX开发环境 优点 支持标准库HAL库LL库代码编辑更“现代化”&#xff1a;代码提示、函数跳转、更高自由度的定制主题等优点多端同步&#xff0c;VS Code和…

【LAMMPS学习】七、加速性能(3)通用技巧

7. 加速性能 7.1.基准测试 7.2.测试性能 7.3.通用技巧 以下是提高模拟性能的通用技巧。它们中的大多数只适用于当前性能中的某些模型和某些瓶颈&#xff0c;因此让您生成的计时数据作为指导。要预测这些选项会产生多大的差异&#xff0c;即使不是不可能&#xff0c;也是很难…

Pathlib库的有哪些神奇功能在Python中

解锁Python利器pathlib的神奇功能 什么是 pathlib&#xff1f; pathlib 是 Python 中用于处理文件路径的模块&#xff0c;它提供了面向对象的方法来操作文件系统路径。使用 pathlib 可以更加直观和安全地处理文件和目录路径。 功能 一些 pathlib 提供的功能包括&#xff1a;…

Jmeter02-1:参数化组件CVS

目录 1、Jmeter组件&#xff1a;参数化概述 1.1 是什么&#xff1f; 1.2 为什么&#xff1f; 1.3 怎么用&#xff1f; 2、Jmeter组件&#xff1a;参数化实现之CSV Data Set Config(重点中重点) 2.1 是什么&#xff1f; 2.2 为什么&#xff1f; 2.3 怎么用&#xff1f; …

【2024年5月备考新增】《2024高项论文精华版(5)项目工作绩效域和度量绩效域》

3 项目工作绩效域 预期目标绩效指标检查方法①高效且有效的项目绩效状态报告:通过状态报告可以表明项目工作有效率且有效果②适合项目和环境的项目过程▲过程的适宜性:证据表明,项目过程是为满足项目和环境的需要而裁剪▲过程相关性和有效性:过程审计和质量保证活动表明,过…

Golang | Leetcode Golang题解之第5题最长回文子串

题目&#xff1a; 题解&#xff1a; func longestPalindrome(s string) string {if s "" {return ""}start, end : 0, 0for i : 0; i < len(s); i {left1, right1 : expandAroundCenter(s, i, i)left2, right2 : expandAroundCenter(s, i, i 1)if ri…

「PHP系列」PHP数组排序及运用场景

文章目录 一、PHP 数组排序二、PHP 数组排序使用场景数据排序介绍数据排序案例 三、相关链接 一、PHP 数组排序 PHP 提供了多种数组排序函数&#xff0c;允许你根据数组元素的值或键进行排序。 sort() sort() 函数用于对数组的元素按升序进行排序。它会修改原始数组&#xf…

把本地项目上传到gitee上

要把本地项目上传到 Gitee&#xff0c;你需要先在 Gitee 上创建一个仓库&#xff0c;然后在本地使用 Git 将项目推送到 Gitee。以下是简要步骤和示例代码&#xff1a; 1、在 Gitee 上创建一个新的仓库。 2、在本地项目目录中初始化 Git&#xff08;如果尚未初始化&#xff09…

python实现全排列(递归和循环)

递归实现全排列可以使用回溯法。具体步骤如下&#xff1a; 将待排列的元素分为两部分&#xff1a;第一个元素&#xff08;固定元素&#xff09;和其余元素。对于固定元素后面的每一个元素&#xff0c;将其与固定元素交换位置&#xff0c;然后递归地对剩余元素进行全排列。递归…

Mysql数据库getshell方法

今天摸鱼时候&#xff0c;突然有人问我不同的数据库getshell的方式&#xff0c;一时间我想到了mysql还有redis未授权访问到getshell的方式&#xff0c;但是仅仅第一时间只想到了这两种&#xff0c;我有查了查资料&#xff0c;找到了上面两种数据库getshell的补充&#xff0c;以…

【面试八股总结】传输控制协议TCP(三)

参考资料 &#xff1a;小林Coding、阿秀、代码随想录 一、TCP拥塞控制⭐ 1. 慢启动 – Slow Start 慢启动是指TCP连接刚建立&#xff0c;一点一点地提速&#xff0c;试探一下网络的承受能力&#xff0c;以免直接扰乱了网络通道的秩序。 慢启动算法&#xff1a; 初始拥塞窗口…

电商技术揭秘五:电商平台的个性化营销与数据分析

文章目录 引言1. 个性化营销的概念与价值1.1 个性化营销的定义1.1.1 个性化营销的基本概念1.1.2 个性化营销在电商领域的重要性 1.2 个性化营销的核心价值1.2.1 提升用户体验1.2.2 增加转化率和客户忠诚度1.2.3 优化营销资源配置 2. 用户画像与行为分析2.1 用户画像的构建2.1.1…

SpringBoot+thymeleaf完成视频记忆播放功能

一、背景 1)客户要做一个视频播放功能,要求是系统能够记录观看人员在看视频时能够记录看到了哪个位置,在下次观看视频的时候能够从该位置进行播放。 2)同时,也要能够记录是谁看了视频,看了百分之多少。 说明:由于时间关系和篇幅原因,我们这里只先讨论第一个要求,第…