之前写过一个死锁的程序,是通过Thread类来实现的,写的不够直观,而且没有附上结果。现在用线程池写一个,并且附上结果。代码如下:
/**
* 测试死锁
* @author shuyweng
*
*/
public class TestDeadLock {
public boolean flag;
public static Object o1 = new Object();
public static Object o2 = new Object();
//线程1锁住o1一秒,一秒后去请求o2,线程2锁住o2,去请求o1
public static void main(String[] args) {
ExecutorService pool = Executors.newCachedThreadPool();
//线程1锁住o1,1秒后锁住o2
pool.execute(new Runnable() {
@Override
public void run() {
//锁住o1
synchronized (o1) {
System.out.println("-------线程1锁住o1");
try {
//锁住o1的情况下,睡眠1秒
Thread.sleep(1000);
System.out.println("--------线程1请求o2");
//锁住o2
synchronized (o2) {
System.out.println("--------线程1获得o2");
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
});
//线程2锁住o2
pool.execute(new Runnable() {
@Override
public void run() {
synchronized (o2) {
System.out.println("-------线程2锁住o2");
System.out.println("-----------线程2请求o1");
synchronized (o1) {
System.out.println("--------线程2获得o1");
}
}
}
});
}
}
运行结果如下:
如上图:程序并没有打印出-线程1获得o2;线程1获得o2。2个线程都在等待对方,此时就是死锁状态。有人会问:为什么jvm没有抛出异常。这是因为jvm对于死锁是不会提醒的。