两个线程,在运行时都在等待对方的锁
这样,便造成了程序的停滞,这种现象称为死锁
示例,Example14.java
代码如下
class DeadLockThread implements Runnable{
static Object chopsticks=new Object(); // 定义Object类型的chopsticks锁对象
static Object knifeAndFork=new Object(); // 定义Object类型的knifeAndFork锁对象
private boolean flag; // 定义boolean类型的变量flag
DeadLockThread(boolean flag){ // 定义有参的构造方法
this.flag=flag;
}
public void run(){
if (flag){
while(true){
// chopsticks锁对象,上的同步代码块
synchronized(chopsticks){
System.out.println(Thread.currentThread().getName()+"---if---chopsticks");
// knifeAndFork锁对象,上的同步代码块
synchronized(knifeAndFork){
System.out.println(Thread.currentThread().getName()+"---if---knifeAndFork");
}
}
}
}else{
while(true){
// knifeAndFork锁对象,上的同步代码块
synchronized(knifeAndFork){
System.out.println(Thread.currentThread().getName()+"---else---knifeAndFork");
// chopsticks锁对象,上的同步代码块
synchronized(chopsticks){
System.out.println(Thread.currentThread().getName()+"---else---chopsticks");
}
}
}
}
}
}
public class Example14{
public static void main(String[] args){
// 创建两个DeadLockThread对象
DeadLockThread d1=new DeadLockThread(true);
DeadLockThread d2=new DeadLockThread(false);
// 创建并开启两个线程
new Thread(d1,"Chinese").start(); // 创建开启线程Chinese
new Thread(d2,"American").start(); // 创建开启线程American
}
}
编译运行
代码说明
创建了Chinese和American两个线程
分别执行run()方法中if和else代码块中的同步代码块
Chinese线程,拥有chopsticks锁,只有获得knifeAndFork锁才能执行完毕
American线程,拥有knifeAndFork锁,只有获得chopsticks锁才能执行完毕
两个线程都需要对方所占用的锁,但是,都无法释放自己所拥有的锁
于是,两个线程都处于挂起状态,从而,造成了死锁问题