多线程——并发——死锁产生于解决

本文介绍了Java中死锁的原理,通过小明小刚刻录与扫描实例展示死锁现象,并提供了解决策略——避免嵌套锁。学习如何正确使用synchronized和顺序获取锁以防止死锁。

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

死锁:过多的同步可能造成相互不释放资源* 从而相互等待,一般发生于同步中持有多个对象的锁

package com.lzy.syn;
/**
 * 死锁:过多的同步可能造成相互不释放资源
 * 从而相互等待,一般发生于同步中持有多个对象的锁
 * @author Administration
 *
 */
public class eDeadLock02 {
public static void main(String[] args) {
	Burn b1=new Burn(1,"小明");
	Burn b2=new Burn(0,"小刚");
	new Thread(b1).start();
	new Thread(b2).start();
	
}
}
//扫描仪
class Scanner{
	
}
//刻录机
class CDWriter{
	
}
//刻录
class Burn implements Runnable{
int choice;
String name;

public Burn(int choice, String name) {
	super();
	this.choice = choice;
	this.name = name;
}
static Scanner scanner=new Scanner();
static CDWriter cdwrite=new CDWriter();
	@Override
	public void run() {
		work();
		
	}
	public void work() {
		if(choice==0) {
			synchronized(scanner) {
				System.out.println("扫描仪扫描"+this.name);
				try {
					Thread.sleep(1000);
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				synchronized(cdwrite) {
					System.out.println("刻录机刻录"+this.name);
				}
			}
			
		}
		else {
			synchronized(cdwrite) {
				System.out.println("刻录机刻录"+this.name);
				try {
					Thread.sleep(1000);
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
				synchronized(scanner) {
					System.out.println("扫描仪扫描"+this.name);
				}
			}
			
		}
	}
	
}

代码主要意思就是小明小刚两个人都需要用扫描仪和刻录机进行扫描刻录,而小刚占用扫描仪,小明占用了刻录机,此时两个进程都被阻塞,双方都希望对方能释放出自己是所需要的资源,但他们都因为不能获得自己所需的资源继续运行,从而无法释放自己占有的资源,并且一直处于这样的僵持状态而形成死锁

若要避免死锁,只需避免“锁套锁”即可,

package com.lzy.syn;
/**
 * 死锁:过多的同步可能造成相互不释放资源
 * 从而相互等待,一般发生于同步中持有多个对象的锁
 * @author Administration
 *
 */
public class eDeadLock02 {
public static void main(String[] args) {
	Burn b1=new Burn(1,"小明");
	Burn b2=new Burn(0,"小刚");
	new Thread(b1).start();
	new Thread(b2).start();
	
}
}
//扫描仪
class Scanner{
	
}
//刻录机
class CDWriter{
	
}
//刻录
class Burn implements Runnable{
int choice;
String name;

public Burn(int choice, String name) {
	super();
	this.choice = choice;
	this.name = name;
}
static Scanner scanner=new Scanner();
static CDWriter cdwrite=new CDWriter();
	@Override
	public void run() {
		work();
		
	}
	public void work() {
		if(choice==0) {
			synchronized(scanner) {
				System.out.println("扫描仪扫描"+this.name);
				try {
					Thread.sleep(1000);
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
//				synchronized(cdwrite) {
//					System.out.println("刻录机刻录"+this.name);
//				}
				
			}
			synchronized(cdwrite) {
				System.out.println("刻录机刻录"+this.name);
			}
			
		}
		else {
			synchronized(cdwrite) {
				System.out.println("刻录机刻录"+this.name);
				try {
					Thread.sleep(1000);
				} catch (InterruptedException e) {
					// TODO Auto-generated catch block
					e.printStackTrace();
				}
//				synchronized(scanner) {
//					System.out.println("扫描仪扫描"+this.name);
//				}
				
			}
			synchronized(scanner) {
				System.out.println("扫描仪扫描"+this.name);
			}
			
		}
	}
	
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值