Java死鎖的理解


        我們有時候操作數據庫的時候會遇到死鎖,那么什么使死鎖呢?它的一個比較官方的定義就是:死鎖是指兩個或兩個以上的進程在執行過程中,由於競爭資源或者由於彼此通信而造成的一種阻塞的現象,若無外力作用,它們都將無法推進下去。此時稱系統處於死鎖狀態或系統產生了死鎖,這些永遠在互相等待的進程稱為死鎖進程。我們也可以通過下面一個小故事來進行簡單的理解。就是說吧有兩個人他們在一起吃飯,但是呢,筷子不夠,A這個人有一支筷子,B這個人也有一支筷子,加入A要吃飯的時候,B把筷子給了A,這樣A就吃上了飯,同理B要吃飯的時候,A把筷子給了B,這樣B也吃上了飯,如果要是這樣的話,就沒有我們什么事了,但是有一天,有一道菜非常好吃,A、B都想先吃,A向B拿筷子,B也先向A拿筷子。兩人都不願意把筷子給對方,那只能一直耗着,等着,那么我們就可以說他們兩個死鎖了。

那么如何使用java來編寫一個死鎖程序呢。簡單來說就是在同步代碼塊中嵌套同步代碼塊,兩個同步代碼塊應用了兩個不同的鎖。A線程的第一個同步代碼塊用到了鎖A,第二個同步代碼塊用到了鎖B。B線程第一個同步代碼塊用到了鎖B,第二個同步代碼塊用到了鎖A。這樣當A線程運行的時候先用了鎖A,還沒有用到鎖B的時候,B線程也啟動了,用到了鎖B,這時A線程要用鎖B,然而這時B線程卻已經占用了鎖B,而B線程繼續運行需要鎖A,可是A線程已經占用了鎖B,這樣話,這兩個線程就出現了死鎖。示例代碼如下:

package com.day05;

/**
 * 死鎖:就是同步代碼塊中嵌套另外一個同步代碼塊
 * 
 * @author Administrator
 *
 */
public class DeadLockDemo {
    public static void main(String[] args) {
        // 創建兩個線程
        DeadLockThread dt1 = new DeadLockThread(false);
        DeadLockThread dt2 = new DeadLockThread(true);
        // 啟動線程
        new Thread(dt1).start();
        new Thread(dt2).start();
    }
}

class DeadLockThread implements Runnable {
    // 標記變量
    private boolean flag;

    public DeadLockThread(boolean flag) {
        super();
        this.flag = flag;
    }

    public void run() {
        // dt1線程執行該方法
        if (flag) {
            synchronized (ThreadLock.locka) {

                System.out.println("if locka!");
                synchronized (ThreadLock.lockb) {
                    System.out.println("if lockb!");
                }
            }
        } // dt2線程執行該方法
        else {
            synchronized (ThreadLock.lockb) {
                System.out.println("else lockb!");
                synchronized (ThreadLock.locka) {
                    System.out.println("else locka!");
                }
            }
        }
    }
}

class ThreadLock {
    static Object locka = new Object();
    static Object lockb = new Object();
}

運行結果:

if locka!
else lockb!

這個時候程序就卡着不動了,也就死鎖了。希望大家可以通過此示例了解死鎖,應盡量在程序中避免死鎖.


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM