検索Java同時プログラミングのリセット-デッドロック現象のデモンストレーションとトラブルシューティング

デッドロック現象のデモンストレーションとトラブルシューティング

IDEツールで次のコードを実行し、終了しないことを確認します。DeadLockDemoクラスをクリックして右クリックし、open in Terminalコンソールを開きます

package thread;

import java.util.concurrent.TimeUnit;

public class DeadLockDemo {
    
    
    public static void main(String[] args) {
    
    
        String lockA = "lockA";
        String lockB = "lockB";
        new Thread(new HoldLockThread(lockA, lockB), "ThreadA").start();
        new Thread(new HoldLockThread(lockB, lockA), "ThreadB").start();
    }
}

class HoldLockThread implements Runnable {
    
    
    private String lockA;
    private String lockB;

    public HoldLockThread(String lockA, String lockB) {
    
    
        this.lockA = lockA;
        this.lockB = lockB;
    }

    @Override
    public void run() {
    
    
        synchronized (lockA) {
    
    
            System.out.println(Thread.currentThread().getName() + "\t自己持有:" + lockA + "\t尝试获取:" + lockB);
            try {
    
    
                TimeUnit.SECONDS.sleep(2);
            } catch (Exception e) {
    
    
                e.printStackTrace();
            }
            synchronized (lockB) {
    
    
                System.out.println(Thread.currentThread().getName() + "\t自己持有:" + lockB + "\t尝试获取:" + lockA);
            }
        }
    }
}

入力ボックスjps -l、スレッドリストの表示、入力jstack 线程ID

jps -l

jpsコマンド

jstack 7104

ここに写真の説明を挿入
このとき、デッドロックが発見されました。Found 1 deadlock.

おすすめ

転載: blog.csdn.net/e891377/article/details/108752132