死锁: 是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。
1 public class DeadLock { 2 public static void main(String[] args) { 3 MyThread m=new MyThread(); 4 /*创建两个线程*/ 5 Thread t1=new Thread(m); 6 Thread t2=new Thread(m); 7 /*线程开始运作*/ 8 t1.start(); 9 t2.start(); 10 } 11 12 } 13 class MyThread implements Runnable{ 14 /*设立标志位,目的是让两个线程分别进入if-else的两个分支*/ 15 public boolean flag=true; 16 @Override 17 public void run() { 18 // TODO Auto-generated method stub 19 if(flag){ 20 /*flag一开始为真,线程t1进入if分支,然后讲flag置假,让接下来的线程进入else分支*/ 21 flag=false; 22 while(true) 23 synchronized (this) { 24 synchronized (this.getClass()) { 25 System.out.println(Thread.currentThread().getName()+"true"); 26 try { Thread.sleep(50); } catch (Exception e) { e.printStackTrace(); } 27 } 28 } 29 }else{ 30 /*t2线程进入该分支,进入死循环*/ 31 while(true) 32 synchronized (this.getClass()) { 33 synchronized (this) { 34 System.out.println(Thread.currentThread().getName()+"false"); 35 try { Thread.sleep(50); } catch (Exception e) { e.printStackTrace(); } 36 } 37 } 38 } 39 } 40
运行结果:
1 Thread-0true 2 Thread-0true 3 Thread-0true 4 Thread-0true 5 Thread-1false 6 Thread-0true 7 Thread-0true 8 Thread-0true 9 Thread-0true 10 Thread-1false 11 Thread-1false 12 Thread-0true 13 Thread-0true 14 Thread-0true 15 Thread-0true 16 Thread-0true 17 Thread-1false
实现死锁的思路:两个线程,分别进入AB两个分支,AB分支的锁是互相嵌套的,设立线程休眠的点应该拥有这样的情况,A拥有B的锁,B拥有A的锁,来吧~互相伤害,哈哈。
黑夜给了我黑色的眼睛,我却用它寻找光明