成人免费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鎖

2017-05-03 16:26:24

MySQL并發死鎖

2015-03-18 09:21:53

編程Java死鎖

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

2023-12-29 09:28:25

Java編程

2015-07-30 10:12:32

JavaNullAssert

2024-07-01 08:00:00

2019-11-21 08:51:56

Java異常控制流

2024-09-29 00:00:00

高并發交易所宕機

2013-03-25 10:15:57

2021-03-01 15:52:14

開源開源軟件陷阱

2022-04-08 08:00:00

NFT數字資產騙局
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美日韩一区二区在线观看 | 欧美在线一区二区三区 | 亚洲日韩中文字幕一区 | 亚洲免费视频网址 | 欧美一级三级在线观看 | 国产专区在线 | 免费在线观看成年人视频 | av在线免费观看网址 | 99色在线| 粉嫩一区二区三区国产精品 | 久久精品视频99 | 国产专区在线 | 国产高清久久久 | 四虎影院免费在线 | 美国一级片在线观看 | 精品福利av导航 | 国产精品视频一区二区三区, | 日韩一区二区三区在线观看 | 91五月婷蜜桃综合 | 狠狠综合久久av一区二区老牛 | 精精国产xxxx视频在线播放7 | 天天射网站 | 日韩影院在线 | 亚洲一区二区三区四区五区午夜 | 亚洲精品一区二区三区蜜桃久 | 国产精品女人久久久 | 亚洲日本一区二区三区四区 | 精品久草 | 黄色一级大片在线免费看产 | 欧美日韩综合视频 | 国产精品久久国产精品久久 | 成人日韩 | 久久欧美精品 | 毛片一级片| 欧美精品在线免费 | 精品美女视频在线观看免费软件 | 成年人在线| 五月天国产视频 | 看a网站| 久久国产综合 | 一区二区三区高清不卡 |