【Java】线程的死锁

1.死锁

不同的线程分别占用对方需要的同步资源不放弃,都在等待对方放弃自己需要的同步资源,就形成了线程的死锁。
image

说明:
出现死锁后,不会出现异常,不会出现提示,只是所有的线程都处于阻塞状态,无法继续。
因此使用同步时,要避免出现死锁问题。

public class DeadLock {
    public static void main(String[] args) {
        StringBuffer s1 = new StringBuffer(); //资源1
        StringBuffer s2 = new StringBuffer();  //资源2

//线程A
        new Thread(){
            @Override
            public void run(){
                synchronized (s1){   //获得资源1的监视器锁
                    s1.append("a");
                    s2.append("1");
                    try {	//让线程 A 休眠 1s 为的是让线程 B 得到CPU执行权
                        Thread.sleep(100);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    synchronized (s2){  //休眠结束想要请求资源2
                        s1.append("b");
                        s2.append("2");

                        System.out.println(s1);
                        System.out.println(s2);
                    }
                }
            }
        }.start();

//线程B
        new Thread(){
            @Override
            public void run(){
                synchronized (s2){  ////获得资源2的监视器锁
                    s1.append("c");
                    s2.append("3");
                    try {
                        Thread.sleep(100);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    synchronized (s1){
                        s1.append("d");
                        s2.append("4");
                        System.out.println(s1);
                        System.out.println(s2);
                    }
                }
            }
        }.start();
    }
}

参考链接:什么是线程死锁?形成条件是什么?如何避免?

posted @ 2022-10-27 14:51  植树chen  阅读(37)  评论(0编辑  收藏  举报