Java编写一个死锁的程序

本文通过两个线程分别获取不同的锁来演示Java中死锁的发生。线程-A首先获得lockA,然后尝试获取lockB;与此同时,线程-B首先获得lockB,然后尝试获取lockA。这种情况下,两个线程都将无限期地等待另一个释放所需的锁,从而导致死锁。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

死锁是在多线程编程中常常遇到的问题,现在用java编写一个简单的死锁程序。

程序在main()方法中启动2个线程,“线程-A”和“线程-B”。 线程-A 先拿到 lockA,再寻求拿到 lockB;线程-B 先拿到locB,再需求拿到lockA,如下图,于是变成循环等待,造成死锁。


代码如下:

public class DeadLockDemo {

	public static void main(String[] args) {
		Object lockA = new Object();
		Object lockB = new Object();
		new Thread(new Runnable() {
			@Override
			public void run() {
				String name = Thread.currentThread().getName();
				synchronized (lockA) {
					System.out.println(name + " got lockA,  want LockB");
					try {
						Thread.sleep(100);
					} catch (InterruptedException e) {

						e.printStackTrace();
					}
					synchronized (lockB) {
						System.out.println(name + " got lockB");
						System.out.println(name + ": say Hello!");
					}
				}
			}
		}, "线程-A").start();

		new Thread(new Runnable() {
			@Override
			public void run() {

				String name = Thread.currentThread().getName();
				synchronized (lockB) {
					System.out.println(name + " got lockB, want LockA");
					try {
						Thread.sleep(100);
					} catch (InterruptedException e) {

						e.printStackTrace();
					}
					synchronized (lockA) {
						System.out.println(name + " got lockA");
						System.out.println(name + ": say Hello!");
					}
				}

			}
		}, "线程-B").start();
	}
}


运行结果:

线程-A got lockA,  want LockB
线程-B got lockB, want LockA

程序死锁了,每个线程都不能完成。




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值