91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

Semaphore怎么在Java中中使用

發布時間:2021-03-24 15:45:47 來源:億速云 閱讀:171 作者:Leah 欄目:編程語言

這期內容當中小編將會給大家帶來有關Semaphore怎么在Java中中使用,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

Semaphore的作用:

在java中,使用了synchronized關鍵字和Lock鎖實現了資源的并發訪問控制,在同一時間只允許唯一了線程進入臨界區訪問資源(讀鎖除外),這樣子控制的主要目的是為了解決多個線程并發同一資源造成的數據不一致的問題。在另外一種場景下,一個資源有多個副本可供同時使用,比如打印機房有多個打印機、廁所有多個坑可供同時使用,這種情況下,Java提供了另外的并發訪問控制--資源的多副本的并發訪問控制,今天學習的信號量Semaphore即是其中的一種。

Semaphore實現原理初探:

Semaphore是用來保護一個或者多個共享資源的訪問,Semaphore內部維護了一個計數器,其值為可以訪問的共享資源的個數。一個線程要訪問共享資源,先獲得信號量,如果信號量的計數器值大于1,意味著有共享資源可以訪問,則使其計數器值減去1,再訪問共享資源。

如果計數器值為0,線程進入休眠。當某個線程使用完共享資源后,釋放信號量,并將信號量內部的計數器加1,之前進入休眠的線程將被喚醒并再次試圖獲得信號量。

就好比一個廁所管理員,站在門口,只有廁所有空位,就開門允許與空側數量等量的人進入廁所。多個人進入廁所后,相當于N個人來分配使用N個空位。為避免多個人來同時競爭同一個側衛,在內部仍然使用鎖來控制資源的同步訪問。

Semaphore的使用:

Semaphore使用時需要先構建一個參數來指定共享資源的數量,Semaphore構造完成后即是獲取Semaphore、共享資源使用完畢后釋放Semaphore。

Semaphore semaphore = new Semaphore(10,true);
semaphore.acquire();
//do something here
semaphore.release();

下面的代碼就是模擬控制商場廁所的并發使用:

public class ResourceManage { 
  private final Semaphore semaphore ; 
  private boolean resourceArray[]; 
  private final ReentrantLock lock; 
  public ResourceManage() { 
    this.resourceArray = new boolean[10];//存放廁所狀態 
    this.semaphore = new Semaphore(10,true);//控制10個共享資源的使用,使用先進先出的公平模式進行共享;公平模式的信號量,先來的先獲得信號量 
    this.lock = new ReentrantLock(true);//公平模式的鎖,先來的先選 
    for(int i=0 ;i<10; i++){ 
      resourceArray[i] = true;//初始化為資源可用的情況 
    } 
  } 
  public void useResource(int userId){ 
 semaphore.acquire(); 
    try{ 
      //semaphore.acquire(); 
      int id = getResourceId();//占到一個坑 
      System.out.print("userId:"+userId+"正在使用資源,資源id:"+id+"\n"); 
      Thread.sleep(100);//do something,相當于于使用資源 
      resourceArray[id] = true;//退出這個坑 
    }catch (InterruptedException e){ 
      e.printStackTrace(); 
    }finally { 
      semaphore.release();//釋放信號量,計數器加1 
    } 
  } 
  private int getResourceId(){ 
    int id = -1; 
 lock.lock();
    try { 
      //lock.lock();//雖然使用了鎖控制同步,但由于只是簡單的一個數組遍歷,效率還是很高的,所以基本不影響性能。 
      for(int i=0; i<10; i++){ 
        if(resourceArray[i]){ 
          resourceArray[i] = false; 
          id = i; 
          break; 
        } 
      } 
    }catch (Exception e){ 
      e.printStackTrace(); 
    }finally { 
      lock.unlock(); 
    } 
    return id; 
  } 
} 
public class ResourceUser implements Runnable{ 
  private ResourceManage resourceManage; 
  private int userId; 
  public ResourceUser(ResourceManage resourceManage, int userId) { 
    this.resourceManage = resourceManage; 
    this.userId = userId; 
  } 
  public void run(){ 
    System.out.print("userId:"+userId+"準備使用資源...\n"); 
    resourceManage.useResource(userId); 
    System.out.print("userId:"+userId+"使用資源完畢...\n"); 
  } 
 
  public static void main(String[] args){ 
    ResourceManage resourceManage = new ResourceManage(); 
    Thread[] threads = new Thread[100]; 
    for (int i = 0; i < 100; i++) { 
      Thread thread = new Thread(new ResourceUser(resourceManage,i));//創建多個資源使用者 
      threads[i] = thread; 
    } 
    for(int i = 0; i < 100; i++){ 
      Thread thread = threads[i]; 
      try { 
        thread.start();//啟動線程 
      }catch (Exception e){ 
        e.printStackTrace(); 
      } 
    } 
  } 
}

最后,Semaphore除了控制資源的多個副本的并發訪問控制,也可以使用二進制信號量來實現類似synchronized關鍵字和Lock鎖的并發訪問控制功能。

上述就是小編為大家分享的Semaphore怎么在Java中中使用了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

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

AI

镇赉县| 汉源县| 平谷区| 泽普县| 左贡县| 保康县| 临汾市| 赤水市| 株洲市| 乌鲁木齐市| 敖汉旗| 正安县| 镇坪县| 凌海市| 唐河县| 丽江市| 阿尔山市| 焦作市| 马尔康县| 科技| 望奎县| 永定县| 颍上县| 汝州市| 新蔡县| 普安县| 渝中区| 普兰县| 巫山县| 蒙城县| 葫芦岛市| 紫云| 海南省| 大冶市| 定兴县| 伊吾县| 大英县| 洪湖市| 永修县| 葵青区| 北票市|