java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java多线程死锁模拟

Java多线程环境下死锁模拟

作者:bkpp976

这篇文章主要介绍了模拟Java多线程环境下的死锁,文章介绍一些死锁的产生条件的相关资料,具有一定的参考价值,需要的小伙伴可以参考一下,希望对你有所帮助

1、死锁产生的条件

注意:前三个条件都只是死锁存在的必要条件,但不是充分条件。第四个条件是充分条件。以上条件同样适用于线程。

2、模拟多线程环境下死锁的产生

/**
 * 死锁产生的四个条件:互斥 请求和保持 不可抢占 循环等待
 * synchronized锁住对象资源,保证互斥和不可抢占
 * 先持有一个资源,再去申请另一个资源->请求和保持
 */
public class DeadLock {

    // 模拟两个资源
    public static Object lock1 = new Object();
    public static Object lock2 = new Object();

    // 先申请lock1资源,再去申请lock2资源
    public static void getLock1First(){
        synchronized (lock1){
            System.out.println("getlock1");
            getLock2();
        }
    }

    public static void getLock2(){
        synchronized (lock2) {
            System.out.println("lock1->lock2");
        }
    }

    // 先申请lock2资源,再申请lock1资源
    public static void getlock2First(){
        synchronized (lock2){
            System.out.println("getlock2");
            getLock1();
        }
    }

    public static void getLock1(){
        synchronized (lock1){
            System.out.println("lock2->lock1");
        }
    }

    public static void main(String[] args) {
        new Thread(){
            @Override
            public void run() {
                // 太难把控线程运行的时机了 也有可能此线程执行完了lock1->lock2的顺序
                // 直接死循环一直运行
                // 总会刚好遇到线程1刚好获得lock1,线程2刚好获得lock2
                while (true){
                    getLock1First();
                }
            }
        }.start();

        new Thread(){
            @Override
            public void run() {
                while (true){
                    getlock2First();
                }
            }
        }.start();
    }
}

死锁:

3、死锁的排查

先进入jdk安装的bin目录,启动命令行,输入命令jps查看运行的线程ID

死锁检测1:

执行jstack -l 线程ID命令

死锁检测2:

可以看到Thread-1Thread-2都在相互等待对方持有的对象的monitor锁释放。

到此这篇关于Java多线程环境下死锁模拟的文章就介绍到这了,更多相关Java多线程死锁模拟内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文