java 线程问题,写一个死锁(原理:只有互相都等待对方放弃资源才会产生死锁)

Posted Advancing Swift

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java 线程问题,写一个死锁(原理:只有互相都等待对方放弃资源才会产生死锁)相关的知识,希望对你有一定的参考价值。

package com.swift;

public class DeadLock implements Runnable {
    private boolean flag;

    DeadLock(boolean flag) {
        this.flag = flag;
    }

    public void run() {
        while (true) {
            if (flag) {
                synchronized ("suo1") {
                    System.out.println(Thread.currentThread().getName()+"if....locka");
                    synchronized ("suo2") {
                        System.out.println(Thread.currentThread().getName()+"if.....lockb");
                    }
                }
            } else {
                synchronized ("suo2") {
                    System.out.println(Thread.currentThread().getName()+"else.....lockb");
                    synchronized ("suo1") {
                        System.out.println(Thread.currentThread().getName()+"else....locka");
                    }
                }
            }
        }
    }

    public static void main(String[] args) {
        
        /*
         * 写一个死锁
         */
        //只有互相都等待对方放弃资源才会产生死锁
        new Thread(new DeadLock(true),"线程1").start();
        new Thread(new DeadLock(false),"线程2").start();
    }
}

同步代码块的锁也可以用对象,如LockA.locka

locka对象为静态 公共

以上是关于java 线程问题,写一个死锁(原理:只有互相都等待对方放弃资源才会产生死锁)的主要内容,如果未能解决你的问题,请参考以下文章

C# 死锁的原理与排查方法详解

java 死锁

死锁相关介绍

Linux下面 多线程死锁问题的调试

java多线程系列-死锁与活锁的区别,死锁与饥饿的区别

如何减少SQLServer死锁发生