成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java并發:如何避免死鎖

開發 前端
一般出現死鎖時,可能會導致CPU、內存等資源消耗過高,導致系統性能下降。也可能導致應用無響應或者假死等等,所以要從多角度進行死鎖的排查。

一般在Java項目里用到鎖的場景不多,有朋友調侃說用到鎖的次數還沒有面試被問到的次數多,哈哈!

1.死鎖如何產生

說句難聽話,鎖一般都很少用到,何況死鎖呢?想產生死鎖還是有點難的,需要滿足2個條件:

共享資源同時只能被一個線程使用,如果已經有一個線程占用了資源,其余線程只能等待,直到資源被釋放。

死鎖情況肯定存在多個資源被多個線程爭搶的情況。

比如線程1持有了資源A,然后去等待獲取資源B,線程2持有了資源B,然后等待獲取資源A,這樣就會形成死鎖。

2.如何避免死鎖

一般有2種方式避免死鎖:

  • 線程一次性獲取需要的全部資源。
  • 獲取鎖時,增加超時動作。如果在一定的時間內獲取不到鎖,則釋放已經獲取的鎖。

3.代碼實踐

/**
 * 避免死鎖,我覺得有2種方式:
 * 1、線程直接一把頭獲取所需要的全部鎖,不要分步
 * 2、線程獲取A之后,再去獲取B,超時仍未獲取到B,則釋放A
 */
public class AvoidDeadLock01 {

    private static Lock lock1 = new ReentrantLock();
    private static Lock lock2 = new ReentrantLock();

    public static void acquireLocks(Lock lock1, Lock lock2) {
        boolean isLock1Acquired = false;
        boolean isLock2Acquired = false;
        while (true) {
            try {
                isLock1Acquired = lock1.tryLock();
                isLock2Acquired = lock2.tryLock();
            } finally {
                if (isLock1Acquired && isLock2Acquired) {
                    return;
                }
                if (isLock1Acquired) {
                    lock1.unlock();
                }
                if (isLock2Acquired) {
                    lock2.unlock();
                }
            }

            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                throw new RuntimeException(e);
            }
        }
    }

    public static void main(String[] args) {
        Thread thread1 = new Thread(() -> {
            acquireLocks(lock1, lock2);
            System.out.println("=====線程1 獲取到了2把鎖=====");
            lock1.unlock();
            lock2.unlock();
        });
        Thread thread2 = new Thread(() -> {
            acquireLocks(lock1, lock2);
            System.out.println("=====線程2 獲取到了2把鎖=====");
            lock1.unlock();
            lock2.unlock();
        });
        thread1.start();
        thread2.start();
    }

}
public class AvoidDeadLock02 {

    private static Lock lock1 = new ReentrantLock();
    private static Lock lock2 = new ReentrantLock();

    public static void acquireLocks(Lock lock1, Lock lock2) {
        boolean isLock1Acquired = false;
        boolean isLock2Acquired = false;

        try {
            while (true) {
                isLock1Acquired = lock1.tryLock(200, TimeUnit.MILLISECONDS);
                if (isLock1Acquired) {
                    isLock2Acquired = lock2.tryLock(200, TimeUnit.MILLISECONDS);
                    if (isLock2Acquired) {
                        break;
                    } else {
                        lock1.unlock();
                    }
                }
            }
        } catch (InterruptedException e) {
            Thread.currentThread().interrupt();
        } finally {
            if (!isLock1Acquired || !isLock2Acquired) {
                if (isLock1Acquired) {
                    lock1.unlock();
                }
                if (isLock2Acquired) {
                    lock2.unlock();
                }
            }
        }
    }

    public static void main(String[] args) {
        Thread thread1 = new Thread(() -> {
            acquireLocks(lock1, lock2);
            System.out.println("=====線程1 獲取到了2把鎖=====");
            lock1.unlock();
            lock2.unlock();
        });
        Thread thread2 = new Thread(() -> {
            acquireLocks(lock1, lock2);
            System.out.println("=====線程2 獲取到了2把鎖=====");
            lock1.unlock();
            lock2.unlock();
        });
        thread1.start();
        thread2.start();
    }

}

4.出現死鎖如何排查

一般出現死鎖時,可能會導致CPU、內存等資源消耗過高,導致系統性能下降。也可能導致應用無響應或者假死等等,所以要從多角度進行死鎖的排查。

首先是用top、df、free等命令查看操作系統的基本情況。然后可以使用jmap、jstack等命令查看JVM線程棧和堆內存的情況。一般出現死鎖時,會在線程棧的信息里出現deadlock字樣。

還可以采用VisualVM、JConsole等工具進行排查。

責任編輯:趙寧寧 來源: 不焦躁程序員
相關推薦

2010-03-16 18:06:29

Java線程死鎖

2019-10-29 16:10:55

死鎖Java并發

2024-11-20 08:00:00

死鎖多線程編程

2010-06-29 17:32:13

SQL Server鎖

2010-07-20 08:56:37

SQL Server鎖

2015-03-18 09:21:53

編程Java死鎖

2017-05-03 16:26:24

MySQL并發死鎖

2021-03-03 08:57:46

java死鎖線程

2023-12-08 18:01:25

Java關鍵字

2009-06-12 16:15:42

死鎖Java虛擬機

2025-03-03 04:00:00

線程安全CPU

2025-05-08 07:03:11

2015-07-30 10:12:32

JavaNullAssert

2024-07-01 08:00:00

2019-11-21 08:51:56

Java異常控制流

2024-07-11 11:42:09

2022-04-08 08:00:00

NFT數字資產騙局

2014-10-15 10:01:12

2013-03-25 10:15:57

2021-03-01 15:52:14

開源開源軟件陷阱
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91亚洲国产成人精品一区二三 | 久久大 | 国产日韩av一区二区 | 欧美黑人一级爽快片淫片高清 | 欧美精品一区二区三区在线播放 | 国产成人精品一区二区三区 | 狠狠插狠狠操 | 中文字幕乱码视频32 | 91精品久久久久 | 亚洲欧美日韩网站 | 在线一区二区三区 | 中文字幕第100页 | 国产精品国产三级国产aⅴ入口 | 91精品国产手机 | 毛片网络| 久久新视频 | 午夜爽爽爽男女免费观看影院 | 国产在线成人 | 亚洲视频区 | 羞羞视频网站在线观看 | 国产精品成人一区二区三区夜夜夜 | 亚洲国产精品久久久久秋霞不卡 | 久久久免费观看视频 | 一级毛片网| 欧美网站一区二区 | 久久久99国产精品免费 | 免费在线成人 | 国产精品成人在线播放 | 中文字幕在线中文 | 狠狠操天天操 | 丁香久久 | 精品日韩 | 中文字幕乱码视频32 | 青青久草 | 亚洲九九 | 欧美成视频 | www.午夜 | 成人精品 | 99精品一区二区 | 特黄色一级毛片 | av网站免费观看 |