中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java線程技術中的死鎖問題怎么解決

發布時間:2022-01-11 10:12:59 來源:億速云 閱讀:142 作者:iii 欄目:編程語言

這篇文章主要介紹“Java線程技術中的死鎖問題怎么解決”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Java線程技術中的死鎖問題怎么解決”文章能幫助大家解決問題。

我們知道,使用 synchronized 關鍵字可以有效的解決線程同步問題,但是如果不恰當的使用 synchronized 關鍵字的話也會出問題,即我們所說的死鎖。死鎖是這樣一種情形:多個線程同時被阻塞,它們中的一個或者全部都在等待某個資源被釋放。由于線程被無限期地阻塞,因此程序不可能正常終止。

我們先寫一個死鎖的例子,再來分析一下死鎖產生的原因:

public class DeadLock {
    public static void main(String[] args) {
        Business business = new Business1();
        //開啟一個線程執行Business類中的functionA方法
        new Thread(new Runnable() {         
            @Override
            public void run() {
                while(true) {
                    business.functionA();
                }
            }
        }).start();
        //開啟另一個線程執行Business類中的functionB方法
        new Thread(new Runnable() {         
            @Override
            public void run() {
                while(true) {
                    business.functionB();
                }
            }
        }).start();
    }
}
class Business { //定義兩個鎖,兩個方法
    //定義兩個鎖
    public static final Object lock_a = new Object();
    public static final Object lock_b = new Object();   
    public void functionA() {
        synchronized(lock_a) {
            System.out.println("---ThreadA---lock_a---");
            synchronized(lock_b) {
                System.out.println("---ThreadA---lock_b---");
            }
        }
    }
    public void functionB() {
        synchronized(lock_b) {
            System.out.println("---ThreadB---lock_b---");
            synchronized(lock_a) {
                System.out.println("---ThreadB---lock_a---");
            }
        }
    }
}

程序的結構很清晰,沒什么難度,先看一下程序的執行結果:

---ThreadA---locka---
---ThreadA---lockb---
---ThreadA---locka---
---ThreadA---lockb---
---ThreadA---locka---
---ThreadA---lockb---
---ThreadA---locka---
---ThreadB---lockb---

從執行結果來看,線程 A 跑著跑著,當線程 B 一跑,啪嘰一下就掛了。我們來分析一下原因:從上面的代碼中可以看出,定義了一個類 Business,該類中維護了兩個鎖和兩個方法,每個方法都是 synchronized 連環套,并且使用的是不同的鎖。好了,現在 main 方法中開啟兩個線程 A 和 B,分別執行 Business 類中的兩個方法。A 優先執行,跑的很爽,當 B 線程也開始執行的時候,問題來了,從執行結果的最后兩行來看,A 線程進入了 functionA方法中的第一個 synchronized,拿到了 lock_a 鎖,B 線程進入了 functionB 中的第一個 synchronized,拿到了 lock_b 鎖,并且兩者的鎖都還沒釋放。接下來就是關鍵了:A 線程進入第二個 synchronized 的時候,發現 lock_b 正在被 B 占用,那沒辦法,它只好被阻塞,等唄~同樣地,B 線程進入第二個 synchronized 的時候,發現 lock_a 正在被 A 占用,那沒辦法,它也只好被阻塞,等唄~好了,兩個就這樣互相等著,你不放,我也不放……死了……

上面這個程序對于理解死鎖很有幫助,因為結構很好,不過個人感覺這個死的還不過癮,因為兩個線程是實現了兩個不同的 Runnable 接口,只不過調用了同一個類的兩個方法而已,因為我把要同步的方法放到一個類中了。下面我把程序改一下,把要同步的代碼放到一個 Runnable 中,讓它一運行就掛掉……

public class DeadLock {    
    public static void main(String[] args) {            
        //開啟兩個線程,分別扔兩個自定義的Runnable進去
        new Thread(new MyRunnable(true)).start();;
        new Thread(new MyRunnable(false)).start();;
    }
}
class MyRunnable implements Runnable
{
    private boolean flag; //用于判斷,執行不同的同步代碼塊 
    MyRunnable(boolean flag) { //構造方法
        this.flag = flag;
    }
    @Override
    public void run()
    {
        if(flag)
        {
            while(true){            
                synchronized(MyLock.lock_a)
                {
                    System.out.println("--threadA---lock_a--");
                    synchronized(MyLock.lock_b)
                    {
                        System.out.println("--threadA---lock_b--");
                    }   
                }
            }
        }
        else
        {
            while(true){            
                synchronized(MyLock.lock_b)
                {
                    System.out.println("--threadB---lock_a--");
                    synchronized(MyLock.lock_a)
                    {
                        System.out.println("--threadB---lock_b--");
                    }   
                }
            }
        }
    }
}
class MyLock //把兩把鎖放到一個類中定義,是為了兩個線程使用的都是這兩把鎖
{
    public static final Object lock_a = new Object();
    public static final Object lock_b = new Object();   
}

這個死鎖就厲害了,一運行,啪嘰一下直接就掛掉了……看下運行結果:

--threadA---locka--
--threadB---lockb--

關于“Java線程技術中的死鎖問題怎么解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

上蔡县| 陇西县| 南投市| 锦屏县| 信阳市| 巨野县| 永年县| 凉山| 丹东市| 金门县| 唐山市| 绥芬河市| 武川县| 乌兰察布市| 宁国市| 彰化县| 洛川县| 神农架林区| 南涧| 钦州市| 策勒县| 湖州市| 当雄县| 开鲁县| 普兰店市| 永城市| 大新县| 云南省| 霍城县| 澎湖县| 房产| 囊谦县| 阳高县| 抚宁县| 英吉沙县| 那曲县| 长沙市| 神农架林区| 桂平市| 绥中县| 楚雄市|