Java线程的死锁

两个线程,在运行时都在等待对方的锁
这样,便造成了程序的停滞,这种现象称为死锁
示例,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
    }
}

编译运行
Java线程的死锁_第1张图片
代码说明
创建了Chinese和American两个线程
分别执行run()方法中if和else代码块中的同步代码块
Chinese线程,拥有chopsticks锁,只有获得knifeAndFork锁才能执行完毕
American线程,拥有knifeAndFork锁,只有获得chopsticks锁才能执行完毕

两个线程都需要对方所占用的锁,但是,都无法释放自己所拥有的锁
于是,两个线程都处于挂起状态,从而,造成了死锁问题

你可能感兴趣的:(————并发)