死锁的产生与避免

什么是死锁

死锁是指两个或两个以上的线程在执行过程中,因争夺资源而造成的互相等待的现象,在无外力作用的情况下,这些线程会一直相互等待而无法继续运行下去。
在这里插入图片描述
死锁的产生必须具备以下四个条件:

  1. 互斥条件: 指线程对己经获取到的资源进行排它性使用 , 即该资源同时只由 一个线程占用。
  2. 请求并持有条件 : 指一个线程己经持有了至少一个 资源 , 但又提出了新的资源请求 ,而新资源己被其他线程占有,所 以当前线程会被阻塞 ,但阻塞的同时并不释放自己己经获取的资源。
  3. 不可剥夺条件 : 指线程获取到的资源在自己使用完之前不能被其他线程抢占 , 只有在自己使用完毕后才由自己释放该资源。
  4. 环路等待条件 : 指在发生死锁时 , 必然存在一个线程→资源的环形链 , 即线程集合{TO , TL T2 ,…, Tn }中的TO 正在等待一个 Tl 占用的资源 , Tl 正在等待 T2 占用的资源,……Tn 正在等待 己被 TO 占用 的资源。
    示例:

public class Wait {
	public static Object lockA = new Object();
	public static Object lockB = new Object();
	
	static class ThreadA extends Thread{
		@Override
		public void run() {
			synchronized (lockA) {
				System.out.println("Thread A get lock A");
				try {
					this.sleep(2000);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				synchronized(lockB) {
					System.out.println("Thread B get lock B");
				}
			}
		}
	}
	
	static class ThreadB extends Thread{
		@Override
		public void run() {
			synchronized (lockB) {
				System.out.println("Thread B get lock B");
				try {
					this.sleep(2000);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				synchronized(lockA) {
					System.out.println("Thread A get lock A");
				}
			}
		}
	}

	public static void main(String[] args) throws InterruptedException {
		ThreadA a = new ThreadA();
		ThreadB b = new ThreadB();
		a.start();
		b.start();
	}

}

结果:
在这里插入图片描述

如何避免线程死锁

造成死锁的原因其实和申请资源的顺序有很大关系 , 使用资源申请的有序性原则就可以避免死锁。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值