您当前的位置:首页 >> 机器人
机器人

Java开发计划之——线程面试篇:死锁和如何避免死锁?

发布时间:2025-09-03

Gate) {

System.out.println("我进不来了");

}

}

},"文静").start();

列车运行结果:

数据分析:这里消除表述器的诱因是因多线程是不是不须转让了上锁smallGate,然后进行时了sleepREM后来就让转让上锁largeGate;而此时多线程文静早已转让了上锁largeGate,比方说就让转让smallGate,于是显现出了教育资源竞争性所致截断赶紧的只能;

只能二:

Object obj1 = new Object();

Object obj2 = new Object();

new Thread(()->{

String name = Thread.currentThread().getName();

synchronized (obj1){

try {

System.out.println(name+ " 赶紧了,必须被唤起!");

obj1.wait();

obj2.notify();

} catch (InterruptedException e) {

e.printStackTrace();

}

}

},"t1").start();

new Thread(()->{

String name = Thread.currentThread().getName();

synchronized (obj2){

try {

System.out.println(name+ " 赶紧了,必须被唤起!");

obj2.wait();

obj1.notify();

} catch (InterruptedException e) {

e.printStackTrace();

}

}

},"t2").start();

列车运行结果:

数据分析:上面表述器的诱因是因为多线程t1和多线程t2分别只转让上锁obj1、obj2,但是因为不不对的互联显现出了,多线程t1进行时了多线程赶紧必须多线程t2唤起,而多线程t2也带入了多线程赶紧必须多线程t1唤起,带入了反向赶紧之前所致了表述器消除。

4. 如何消除表述器

(1)维持加上锁次序:当多个多线程都必须加不同的几个上锁的时候(例如上述只能一的表述器),按照不同的次序枷上锁那么就意味著所致表述器消除,所以我们如果能确保所有的多线程都是按照不同的次序得到上锁,那么表述器就不会发生。

(2)赚取上锁去掉时限:上述表述器示例只能二就是因为显现出了赚取上锁最终无限赶紧的只能,如果我们在赚取上锁的时候进行时限时赶紧,例如wait(1000)或者适用ReentrantLock的tryLock(1,TimeUntil.SECONDS)这样在指定时间内赚取上锁最终就不赶紧;

(3)进行时表述器检测:我们可以通过一些策略检查和示例并持续性其显现出表述器。

5. 表述器检测

Java之前表述器检测策略最多的就是适用JDK略带的jstack和JConsole工具箱了。下面我们以jstack为例来进行时表述器的检测;

(1)不须列车运行我们的示例处理程序

(2)适用JDK的工具箱JPS查询列车运行的数据流信息,如下:

(3)适用jps查想到的数据流ID对其进行时jstack 数据流数据分析

数据分析的结果推移,我们往下找可以想到“Found one Java-level deadlock”,表示处理程序之前辨认出了一个表述器。

上海妇科医院哪家正规
信阳看妇科哪个医院好
武汉妇科医院哪个最好
贵阳强直医院哪家更好
陕西白癜风医院排行榜

上一篇: 韩文秀:2022要慎重印发有收缩效应的政策

下一篇: 顺义就诊病例轨迹涉及故宫博物院

友情链接