死锁的四个必要条件

article/2025/9/21 19:19:53

死锁在高并发中是一个常见的名词。产生的四个必要条件如下:

  1. 互斥条件:一个资源同一时间能且只能被一个线程访问;

  1. 不可掠夺:当资源被一个线程占用时,其他线程不可抢夺该资源;

  1. 请求与等待:当资源被一个线程占用时,其他线程只能等待资源的释放再拥有;

  1. 循环等待:指的是若干线程形成头尾相接的情况,将所有资源都占用导致的整体死锁或局部死锁。

图演示

线程1依次占用资源1和资源2,当尝试占用资源2时,发现该资源被线程2占用,此时只能等待线程2的释放,此时处于阻塞状态;

线程2依次占用资源2和资源1,当尝试占用资源1时,发现该资源被线程1占用,此时只能等待线程1的释放,此时处于阻塞状态。

这两个线程无限的等待对方资源的释放,则成为死锁。

代码演示

package com.lidantao.deadLock;import java.util.concurrent.TimeUnit;/*** @author Cola* @Date 2023年02月16日 10:41:00*/
public class Demo {public static void main(String[] args) throws InterruptedException {Object obj1 = new Object();Object obj2 = new Object();Thread t1 = new Thread(() -> {synchronized (obj1) {try {System.out.println("====线程1尝试占用资源1====");obj1.hashCode();System.out.println("====线程1已经占用资源1====");TimeUnit.SECONDS.sleep(3);System.out.println("======线程1尝试占用资源2======");synchronized (obj2) {obj2.hashCode();System.out.println("====线程1已经占用资源2====");}} catch (InterruptedException e) {e.printStackTrace();}}}, "线程1");Thread t2 = new Thread(() -> {synchronized (obj2) {try {System.out.println("====线程2尝试占用资源2====");obj2.hashCode();System.out.println("====线程2已经占用资源2====");TimeUnit.SECONDS.sleep(3);System.out.println("======线程2尝试占用资源1======");synchronized (obj1){obj1.hashCode();System.out.println("====线程2已经占用资源1====");}} catch (InterruptedException e) {e.printStackTrace();}}}, "线程2");// 启动线程t1.start();t2.start();// t1业务完成t1.join();System.out.println("====== t1线程业务已完成 ======");// t2业务完成t2.join();System.out.println("====== t2线程业务已完成 ======");}
}

控制台输出,两线程彼此等待资源释放,无法停止线程

经jconsole验证,线程1与线程2掠夺资源产生死锁

处理死锁

既然了解了死锁的必要条件,那么我们只要破坏其中一个条件则可避免产生死锁。

  1. 通常我们在业务中,可以设置等待时间。例如尝试占用资源时,设置等待时间,时间内未获得资源,则放弃尝试,避免程序长时间等待,占用过高的CPU资源。

  1. 尽量一次只占用一个资源,不要一次嵌套的占用多个资源,占用资源链越长,越容易产生死锁问题。


http://chatgpt.dhexx.cn/article/X3fxb71Y.shtml

相关文章

div在html垂直居中,div 垂直居中(css div水平垂直居中六种方法)

div垂直居中 div垂直居中代码示例如下: 前台效果如下图所示: 如图所示,div中的文字垂直居中。其中主要的属性就是line-height。 line-height属性设置行间的间隔(行高即垂直方向)。 line-height属性会影响行框的规划。在应用到一个块级元素时&…

使用css3将一个div水平和垂直居中显示

使用css3将一个div水平和垂直居中显示 方案一: div绝对定位水平垂直居中【margin:auto实现绝对定位元素的居中】, 代码两个关键点:1.上下左右均0位置定位; 2.margin: auto; 其width、height如何更改都是居中显示的,兼容…

CSS 实现DIV水平垂直居中(二)

CSS 实现DIV垂直居中 上期介绍了CSS实现div水平居中的五种方法,下面介绍CSS实现div垂直居中的几种方法。上篇:CSS 实现DIV水平居中 首先还是和上期同样的两个div盒子,以下方法实现div垂直居中,效果如图: 1.通过padding上下留白实…

div中的内容水平垂直居中

1. div高度自适应的情况 div在不设置高度的时候,会被里面的内容撑开,内容自动填充在div中,无论是一行内容还是多行内容,此时不需要设置垂直居中,内容自动在中间的, 想要看的更直观些,只需要加上…

Div水平垂直居中

(1)父元素设置弹性盒子display:flex; 再加上justify-content:center;align-items:center; 推荐 (2)使用top:50% left:50% 以及margin-top 和 margin-left 来进行定位 注意: 必须知道盒子的具体的宽和高,否…

html 中div垂直居中的三种方式

1、第一种&#xff1a; <style type"text/css"> <!-- .con_div{ width:400px; height:300px; border:1px solid #777; text-align:center; display:table-cell; vertical-align:middle; background:red; color:#fff; lin…

如何让一个div水平垂直居中

在工作中 经常会碰到让一个div框针对某个模块水平垂直居中 针对这种情况 有多种方法 现在一一实现一下 一. div绝对定位水平垂直居中 margin 负间距 代码: .box {width: 200px;height: 200px;background: yellow;position: absolute;left: 50%;top: 50%;margin-left: -100px;m…

CSS实现DIV垂直水平居中

CSS实现DIV垂直水平居中 在页面设计中&#xff0c;很多地方都需要div的垂直水平居中&#xff0c;在前端开篇的学习中&#xff0c;也是使用较多的地方&#xff0c;所以我整理了三种方法帮助大家去解决问题&#xff0c;代码可直接使用&#xff0c;仅供参考学习。 方法 方法一&a…

div文字垂直居中的方法有哪些?

首先我们应该知道文字的水平居中比较简单,行级元素设置其父元素的text-aligncenter,块级元素设置其本身的left和rightmargins为auto即可。但是div文字的垂直居中就不是那么简单了,所以我们就来具体看看div文字垂直居中的几种实现方法。 1、vertical-align属性让文字居中 ver…

关于让div元素垂直居中的几种方法

如何用让嵌套在里面的div居中 本人是一个前端新手&#xff0c;如何让两个相互嵌套的div&#xff0c;让里面的div居中是一个比较简单的问题&#xff0c;面试也常问&#xff0c;我就从其他博客中提取稍微总结一下&#xff08;转载侵删&#xff09;&#xff0c;也加了一点自己的困…

css 文本和div垂直居中方法汇总

在样式布局中&#xff0c;我们经常碰到需要将元素居中。通过css实现元素的水平居中较为简单&#xff1a;对文本&#xff0c;只需要对其父级元素设置text-align: center;&#xff0c;而对div等块级元素&#xff0c;只需要设置其left和right的margin值为auto。要实现元素的垂直居…

CSS——div垂直居中及div内文字垂直居中

最近做demo时&#xff0c;经常需要div垂直居中或者让div内文字相对div垂直居中。水平居中比较简单&#xff0c;就不多说了&#xff0c;这里主要记录一下垂直居中的一些方法。 一、div垂直居中的一些方法&#xff1a; 1.当height、width固定大小时&#xff0c; <!DOCTYPE htm…

div水平垂直居中的常用方法

html5的文档结构 <!DOCTYPE html> <html lang"zh"> <head><meta charset"UTF-8"><title></title></head> <body></body> </html> 效果图&#xff1a; 1.通过设置绝对定位和设置负边距实现&…

div水平垂直居中的七种方法

学习笔记&#xff08;一&#xff09; div水平垂直居中的七种方法 文章目录 学习笔记&#xff08;一&#xff09;前言一、绝对定位法1.方法一2.方法二3.方法三4.方法四 二、flex布局法1.方法五 三、将小div转成行内块1.方法六 四、网格布局1.方法七 总结 前言 在写小demo过程中…

div 垂直居中的六种方法

利用CSS进行元素的水平居中&#xff0c;比较简单&#xff0c;行级元素设置其父元素的text-align center&#xff0c;块级元素设置其本身的left 和 right margins为auto即可。本文收集了六种利用css进行元素的垂直居中的方法&#xff0c;每一种适用于不同的情况&#xff0c;在实…

CSS进阶篇--div中的内容垂直居中的五种方法

一、行高&#xff08;line-height&#xff09;法 如果要垂直居中的只有一行或几个文字&#xff0c;那它的制作最为简单&#xff0c;只要让文字的行高和容器的高度相同即可&#xff0c;比如&#xff1a; p { height:30px; line-height:30px; width:100px; overflow:hidden; }这段…

div水平垂直居中的四种方式

让div水平居中的方式&#xff0c;我所知道的就是以下这四种。 文章目录 一、margin二、绝对定位三、子元素绝对定位父元素相对定位四、flex布局总结 一、margin 第一种方式我们可以利用外边距属性来使div水平垂直居中 先来看一段有问题的代码 <!DOCTYPE html> <ht…

div水平垂直居中方法汇总(共六种)

文章目录 第一种第二种第三种第四种第五种第六种 第一种 绝对定位方法&#xff1a;不确定当前div的宽度和高度&#xff0c;采用 transform: translate(-50%,-50%); 当前div的父级添加相对定位&#xff08;position: relative;&#xff09; <!DOCTYPE html> <html lang…

缓存设计(本地缓存 + 分布式缓存)

缓存设计 前言正文缓存对象缓存服务缓存策略本地缓存Guava的使用 分布式缓存Redis缓存分布式缓存的生命周期分布式缓存的一致性问题 源码解读从缓存中获取秒杀品 分布式锁 总结参考链接 前言 大家好&#xff0c;我是练习两年半的Java练习生&#xff0c;本篇文章会分析秒杀系统…

分布式缓存解决方案

高并发首选&#xff1a;缓存 项目代码下载地址&#xff1a;https://gitee.com/tyytx/distrbute-demo.git 接口高并发的解决思路&#xff1a;1、加缓存 2、数据静态化 3、集群 4、分布式 5、同步转异步 6、限流、降级 适合加缓存的场景&#xff1a;读多写少的数据&#xff0c;不…