Java模拟死锁

synchronized实现

java 复制代码
package com.example.demo.dealock.synchronize;

/**
 * @author chenwei
 * @date 2025-12-17 17:02
 * @description
 */
public class DeadLockDemo {

    public final static Object lockA = new Object();
    public final static Object lockB = new Object();

    public static void main(String[] args){
        new Thread("死锁线程1"){
            @Override
            public void run() {
                synchronized (lockA){
                    System.out.println("Thread 1: Holding lock A...");
                    try {
                        Thread.sleep(100);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("Thread 1: Waiting for lock B...");
                    synchronized (lockB){
                        System.out.println("Thread 1: Acquired lock B!");
                    }
                }
            }
        }.start();

        new Thread("死锁线程2"){
            @Override
            public void run() {
                synchronized (lockB){
                    System.out.println("Thread 2: Holding lock B...");
                    try {
                        Thread.sleep(100);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("Thread 2: Waiting for lock A...");
                    synchronized (lockA){
                        System.out.println("Thread 2: Acquired lock A!");
                    }
                }
            }
        }.start();
    }
}

ReentrantLock实现

java 复制代码
package com.example.demo.dealock.reentrenlock;

import java.util.concurrent.locks.ReentrantLock;

/**
 * @author chenwei
 * @date 2025-12-17 17:14
 * @description
 */
public class DeadLockDemo {

    public final static ReentrantLock lockA = new ReentrantLock();
    public final static ReentrantLock lockB = new ReentrantLock();

    public static void main(String[] args){
        new Thread("死锁线程1"){
            @Override
            public void run() {
                lockA.lock();
                System.out.println("Thread 1: Holding lock A...");
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println("Thread 1: Waiting for lock B...");
                {
                    lockB.lock();
                    System.out.println("Thread 1: Acquired lock B!");
                    lockB.unlock();
                }
                lockA.unlock();
            }
        }.start();

        new Thread("死锁线程2"){
            @Override
            public void run() {
                lockB.lock();
                System.out.println("Thread 2: Holding lock B...");
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println("Thread 2: Waiting for lock A...");
                {
                    lockA.lock();
                    System.out.println("Thread 2: Acquired lock A!");
                    lockA.unlock();
                }
                lockB.unlock();
            }
        }.start();
    }
}
相关推荐
Rhys..13 小时前
Playwright + JS 进行页面跳转测试
开发语言·前端·javascript
oscar99913 小时前
深入解析不安全反序列化漏洞与防护[高风险]
开发语言·python·安全
项目題供诗13 小时前
C语言基础(十)
c语言·开发语言
代码游侠13 小时前
学习笔记——GPIO按键与中断系统
c语言·开发语言·arm开发·笔记·嵌入式硬件·学习·重构
R-sz13 小时前
app登录接口实现,基于JWT的APP登录认证系统实现方案
java·开发语言·python
无籽西瓜a13 小时前
ArrayList和LinkedList的区别
java
Elieal13 小时前
@Api 系列注解
java·开发语言
Remember_99313 小时前
【数据结构】深入理解Map和Set:从搜索树到哈希表的完整解析
java·开发语言·数据结构·算法·leetcode·哈希算法·散列表
小楼v13 小时前
消息队列的核心概念与应用(RabbitMQ快速入门)
java·后端·消息队列·rabbitmq·死信队列·交换机·安装步骤
浅念-13 小时前
C++第一课
开发语言·c++·经验分享·笔记·学习·算法