java死鎖小案例
阿新 • • 發佈:2020-09-15
public class thread { //死鎖的情況 public static void main(String[] args){ new Thread("瘦子"){ @Override public void run(){ while (true){ //巢狀鎖資源的使用 synchronized ("筷子A"){ System.out.println(getName()+"獲取到了筷子A,等待獲取筷子B"); synchronized ("筷子B"){ System.out.println(getName()+"獲取到了筷子A,獲取筷子B,吃飯"); } } } } }.start(); new Thread("胖子"){ @Overridepublic void run(){ while (true){ //巢狀鎖資源的使用 synchronized ("筷子B"){ System.out.println(getName()+"獲取到了筷子B,等待獲取筷子A"); synchronized ("筷子A"){ System.out.println(getName()+"獲取到了筷子B,獲取筷子A,吃飯"); } } } } }.start(); } }
執行結果:
D:\jdk\bin\java.exe "-javaagent:D:\ideaIU\IntelliJ IDEA\lib\idea_rt.jar=2593:D:\ideaIU\IntelliJ IDEA\bin" -Dfile.encoding=UTF-8 -classpath D:\jdk\jre\lib\charsets.jar;D:\jdk\jre\lib\deploy.jar;D:\jdk\jre\lib\ext\access-bridge-64.jar;D:\jdk\jre\lib\ext\cldrdata.jar;D:\jdk\jre\lib\ext\dnsns.jar;D:\jdk\jre\lib\ext\jaccess.jar;D:\jdk\jre\lib\ext\jfxrt.jar;D:\jdk\jre\lib\ext\localedata.jar;D:\jdk\jre\lib\ext\nashorn.jar;D:\jdk\jre\lib\ext\sunec.jar;D:\jdk\jre\lib\ext\sunjce_provider.jar;D:\jdk\jre\lib\ext\sunmscapi.jar;D:\jdk\jre\lib\ext\sunpkcs11.jar;D:\jdk\jre\lib\ext\zipfs.jar;D:\jdk\jre\lib\javaws.jar;D:\jdk\jre\lib\jce.jar;D:\jdk\jre\lib\jfr.jar;D:\jdk\jre\lib\jfxswt.jar;D:\jdk\jre\lib\jsse.jar;D:\jdk\jre\lib\management-agent.jar;D:\jdk\jre\lib\plugin.jar;D:\jdk\jre\lib\resources.jar;D:\jdk\jre\lib\rt.jar;E:\java0615\Four\sisuo\target\classes com.offcn.thread
瘦子獲取到了筷子A,等待獲取筷子B
瘦子獲取到了筷子A,獲取筷子B,吃飯
瘦子獲取到了筷子A,等待獲取筷子B
瘦子獲取到了筷子A,獲取筷子B,吃飯
瘦子獲取到了筷子A,等待獲取筷子B
瘦子獲取到了筷子A,獲取筷子B,吃飯
瘦子獲取到了筷子A,等待獲取筷子B
瘦子獲取到了筷子A,獲取筷子B,吃飯
瘦子獲取到了筷子A,等待獲取筷子B
瘦子獲取到了筷子A,獲取筷子B,吃飯
瘦子獲取到了筷子A,等待獲取筷子B
瘦子獲取到了筷子A,獲取筷子B,吃飯
瘦子獲取到了筷子A,等待獲取筷子B
瘦子獲取到了筷子A,獲取筷子B,吃飯
瘦子獲取到了筷子A,等待獲取筷子B
瘦子獲取到了筷子A,獲取筷子B,吃飯
瘦子獲取到了筷子A,等待獲取筷子B
瘦子獲取到了筷子A,獲取筷子B,吃飯
瘦子獲取到了筷子A,等待獲取筷子B
胖子獲取到了筷子B,等待獲取筷子A