出现死锁的前提条件:
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......");
}
}
}
}
}