java 中多线程之死锁浅析

出现死锁的前提条件:

1.必须是至少2个以上的线程在执行;

2.同时要保证其中至少有两个线程中的锁(至少有两个)是相同的,而且都有锁的嵌套;


分析:首先要明确的是当两个线程都拥有相同的锁时候,谁先拿到锁,谁就有执行权(比如线程①先拿到执行权),同时②线程就没有执行权,除非①线程执行完毕释放了锁后,②线程才能执行。

然后看下面一个例子:我在例子中为大家分析死锁是怎么产生的

class DeadLock 
{
	public static void main(String[] args) 
	{
		Thread t1 = new Thread(new Test(true));
		Thread t2 = new Thread(new Test(false));
		t1.start();
		t2.start();
	}
}
class Test implements Runnable
{
	private boolean flag;
	static Object locka = new Object();//假如你把前面的static 去掉了,那么就不会出现死锁,为啥呢?因为锁不一样了,是4个不一样的锁(因为你new Test(true)和new Test(false));

	static Object lockb = new Object();
	Test(boolean flag)
	{
		this.flag = flag;
	}
	public void run()
	{
		if(flag)
		{
			synchronized(locka)
			{
				System.out.println("if locka..");//假如t1线程先拿到cpu执行权,那么运行到这一行打印完if locka..后,因某种原因有可能t1暂时休眠了,t2开始拿到cpu执行权,打印完else lockb..后,就不能在打印else locka..了,因为他进不去,为啥呢,因为t1拿着锁locka的钥匙呢,这时候有可能t1醒了,但是他打印不了if lockb..,因为t2拿着锁lokcb的钥匙呢  这样就锁死了。也就是说谁拿着钥匙,谁就能开锁,就能执行,虽然别人有相同的锁但是你没有钥匙,那就白搭。
				synchronized(lockb)
				{
					System.out.println("if lockb..");
				}
			}	
		}
		else
		{	
			synchronized(lockb)
			{
				System.out.println("else lockb......");
				synchronized(locka)
				{
					System.out.println("else locka......");
				}
			}
		}
	}
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值