转自:
http://www.java265.com/JavaCourse/202204/3181.html
下文笔者讲述Java中产生死锁的方法分享,如下所示
死锁的简介
死锁:
多个线程互相阻塞,
这里面一个线程或多个线程等待某个资源被释放,
此时就会造成线程被无限期地阻塞,程序无法正常终止
我们将这种现象称之为“死锁”
死锁产生的四个必要条件
1.某些线程间资源互斥使用,当某个资源被一个线程使用(占有)时,其他某个(或多个)线程不能使用
2.不可抢占,资源请求者无法从别的线程中夺取资源
3.请求和保持,线程请求资源后,再请求其他资源时,还未对原资料放弃持有
4.循环等待,即存在一个等待队列:P1占有P2的资源,P2占有P3的资源,P3占有P1的资源。这样就形成了一个等待环路。
当以上四个条件都成立时,此时就会产生死锁
例:
package com.java265.other; import java.util.Date; public class Test16 { public static String obj1 = \"java265.com-1\"; public static String obj2 = \"java265.com-2\"; public static void main(String[] args) { LockA a = new LockA(); new Thread(a).start(); LockB b = new LockB(); new Thread(b).start(); } } class LockA implements Runnable { public void run() { try { System.out.println(new Date().toString() + \" LockA 开始执行\"); while (true) { synchronized (Test16.obj1) { System.out.println(new Date().toString() + \" LockA 锁住 obj1\"); Thread.sleep(3000); // 此处等待是给B能锁住机会 synchronized (Test16.obj2) { System.out.println(new Date().toString() + \" LockA 锁住 obj2\"); Thread.sleep(60 * 1000); // 为测试,占用了就不放 } } } } catch (Exception e) { e.printStackTrace(); } } } class LockB implements Runnable { public void run() { try { System.out.println(new Date().toString() + \" LockB 开始执行\"); while (true) { synchronized (Test16.obj2) { System.out.println(new Date().toString() + \" LockB 锁住 obj2\"); Thread.sleep(3000); // 此处等待是给A能锁住机会 synchronized (Test16.obj1) { System.out.println(new Date().toString() + \" LockB 锁住 obj1\"); Thread.sleep(60 * 1000); // 为测试,占用了就不放 } } } } catch (Exception e) { e.printStackTrace(); } } } ------以上程序将产生死锁------- Thu Apr 28 22:35:45 CST 2022 LockB 开始执行 Thu Apr 28 22:35:45 CST 2022 LockA 开始执行 Thu Apr 28 22:35:45 CST 2022 LockB 锁住 obj2 Thu Apr 28 22:35:45 CST 2022 LockA 锁住 obj1
来源:https://www.cnblogs.com/java265/p/16204905.html
本站部分图文来源于网络,如有侵权请联系删除。