java可重入鎖的意義

java默認鎖的機制都是非公平的,非公平的意思就是線程一,線程二同時取循環執行一串被鎖住的代碼塊,執行的先後順序是不確定的,也就是說不一行是先來後到的,這就是非公平。執行結果是下面這樣,這就是默認的線程調度方式是非公平的。

public class FairLock implements Runnable{
    public static ReentrantLock fairLock = new ReentrantLock();

    public void run() {
        while (true) {
            try {
                fairLock.lock();
                System.out.println(Thread.currentThread().getName()+",獲得鎖!");
            }finally {
                fairLock.unlock();
            }
        }
    }
    public static void main(String[] args) {
        FairLock fairLock = new FairLock();
        Thread t1 = new Thread(fairLock, "線程1");
        Thread t2 = new Thread(fairLock, "線程2");
        t1.start();t2.start();
    }
}

線程1,獲得鎖!
線程1,獲得鎖!
線程1,獲得鎖!
線程1,獲得鎖!
線程1,獲得鎖!
線程1,獲得鎖!
線程1,獲得鎖!
線程1,獲得鎖!
線程2,獲得鎖!
線程2,獲得鎖!
線程2,獲得鎖!
線程2,獲得鎖!
public class FairLock implements Runnable{
    public static ReentrantLock fairLock = new ReentrantLock(true);

    public void run() {
        while (true) {
            try {
                fairLock.lock();
                System.out.println(Thread.currentThread().getName()+",獲得鎖!");
            }finally {
                fairLock.unlock();
            }
        }
    }
    public static void main(String[] args) {
        FairLock fairLock = new FairLock();
        Thread t1 = new Thread(fairLock, "線程1");
        Thread t2 = new Thread(fairLock, "線程2");
        t1.start();t2.start();
    }
}

這個代碼和上面都是一樣的  只是reentrantLock中的初始化有一個true ,new ReentrantLock(true);
這個true的意思就是讓鎖是非重入的,也就是說多個線程循環請求鎖的時候,是按照先後順序執行的,即先來後到,這就是公平鎖。

線程1,獲得鎖!
線程1,獲得鎖!
線程1,獲得鎖!
線程2,獲得鎖!
線程1,獲得鎖!
線程2,獲得鎖!
線程1,獲得鎖!
線程2,獲得鎖!
#問題:既然是公平的那爲什麼輸出結果顯示前面三次都是線程一在執行,那是因爲線程二剛開始沒有被cpu分配,請求未到達,到達後基本會交替執行。但也不是絕對的,這個公平是相對的,先來後到,有可能在某個瞬間線程一連續來了兩次,線程二因爲處理任務耗時長來得慢,那麼也是會連續兩次執行線程一。

#可重入鎖的概念就是一個線程可以連續兩次獲得鎖資源,每次獲取的時候內部有一個計數器stat  會加1,釋放一個減去一,直到計數器爲零,這個鎖纔可以背其他的線程獲取。

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章