同步锁使用的弊端---死锁

1.什么是死锁
当线程任务中出现了许多同步(多个锁)时,如果同步中嵌套了同步。这是容易引发一种现象:程序处于无限等待的状态,这种现象我们称之为死锁。

这里先创建两个唯一的锁

package cn.itcast.demo04;

public class LockA {
	//私有构造器,保证这个锁唯一
	private LockA(){}
	//只希望本类调用,不希望外类new,保证唯一
	
	//外面的类不能new,只能静态类名调用静态成员变量
	public static final LockA locka = new LockA();
}

package cn.itcast.demo04;

public class LockB{
	private LockB(){}
	//只希望本类调用,不希望外类new,保证唯一
	public static final LockB lockb = new LockB();
}

这里是Runable的实现类

package cn.itcast.demo04;

public class DeadLock implements Runnable {
	private int i = 0;

	// 重写run方法
	public void run() {
		while (true) {
			if (i % 2 == 0) {
				// 如果A是偶数,先进入A同步,在进入B同步
				synchronized (LockA.locka) {
					System.out.println("进入if语句中的locka");
					synchronized (LockB.lockb) {
						System.out.println("进入if语句中的lockb");
					}
				}
			} else {
				synchronized (LockB.lockb) {
					System.out.println("进入else语句中的lockb");
					synchronized (LockA.locka) {
						System.out.println("进入else语句中的locka");
					}
				}
			}
			i++;
		}
	}
}

这里实现死锁

package cn.itcast.demo04;

public class DeadLockDemo {
public static void main(String[] args) {
	//创建Runnable接口的实现类
	DeadLock dead = new DeadLock();
	Thread t0 = new Thread(dead); 
	Thread t1 = new Thread(dead); 
	
	t0.start();
	t1.start();
}
}

结果如下图
在这里插入图片描述
右上角的红点表示程序尚未结束,因为此时,上面的同步等待下面的同步释放锁B,而下面的同步等待上面的同步释放锁A,造成了两个程序互相等待,而无法让程序继续下去,即发生了死锁现象。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值