不可重入鎖和可重入鎖

 

 

 

 

不可重入鎖也叫自旋鎖

  指當一個方法調用了鎖之後,如持有本鎖的另一個方法也想執行,將會進入等待。那麼想要使用這個方法必須先釋放鎖方可調用

  

複製代碼
public class Lock{
    private boolean isLocked = false;
    public synchronized void lock() throws InterruptedException{
        while(isLocked){    
            wait();
        }
        isLocked = true;
    }
    public synchronized void unlock(){
        isLocked = false;
        notify();
    }
}
複製代碼

 

可重入鎖

  指同一個線程裏,持有此鎖的兩個方法將均會執行,不需要先釋放,但是另一個持有此鎖的線程必須等待鎖釋放後才能使用

  java裏,可重入鎖,如 synchronized

複製代碼
public class Lock{
    boolean isLocked = false;
    Thread  lockedBy = null;
    int lockedCount = 0;
    public synchronized void lock()
            throws InterruptedException{
        Thread thread = Thread.currentThread();
        while(isLocked && lockedBy != thread){
            wait();
        }
        isLocked = true;
        lockedCount++;
        lockedBy = thread;
    }
    public synchronized void unlock(){
        if(Thread.currentThread() == this.lockedBy){
            lockedCount--;
            if(lockedCount == 0){
                isLocked = false;
                notify();
            }
        }
    }
}
複製代碼

不可重入鎖例子的話,如下調用

複製代碼
public class Count{
    Lock lock = new Lock();
    public void print(){
        lock.lock();
        doAdd();
        lock.unlock();
    }
    public void doAdd(){
        lock.lock();
        //do something
        lock.unlock();
    }
}
複製代碼

當調用print的時候,由於獲得鎖,導致doAdd使用時陷入while循環而等待,所以需要先將鎖釋放後纔可使用

 
標籤: 
 
https://www.cnblogs.com/fengfenghuifei/p/10509661.html
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章