Java之多線程 Semaphore(訊號量)

來源:互聯網
上載者:User

標籤:

  一個計數訊號量。從概念上講,訊號量維護了一個許可集。如有必要,在許可可用前會阻塞每一個 acquire(),然後再擷取該許可。每個 release() 添加一個許可,從而可能釋放一個正在阻塞的擷取者。但是,不使用實際的許可對象,Semaphore 只對可用許可的號碼進行計數,並採取相應的行動。拿到訊號量的線程可以進入代碼,否則就等待。通過acquire()和release()擷取和釋放訪問許可。

 

相關方法:acquire
public void acquire()             throws InterruptedException
從此訊號量擷取一個許可,在提供一個許可前一直將線程阻塞,否則線程被中斷。擷取一個許可(如果提供了一個)並立即返回,將可用的許可數減 1。

 

如果沒有可用的許可,則在發生以下兩種情況之一前,禁止將當前線程用於線程安排目的並使其處於休眠狀態:

  • 某些其他線程調用此訊號量的 release() 方法,並且當前線程是下一個要被分配許可的線程;或者
  • 其他某些線程中斷當前線程。

如果當前線程:

  • 被此方法將其已中止狀態設定為 on ;或者
  • 在等待許可時被中斷

則拋出 InterruptedException,並且清除當前線程的已中止狀態。

拋出:
InterruptedException - 如果當前線程被中斷
release
public void release()
釋放一個許可,將其返回給訊號量。釋放一個許可,將可用的許可數增加 1。如果任意線程試圖擷取許可,則選中一個線程並將剛剛釋放的許可給予它。然後針對線程安排目的啟用(或再啟用)該線程。

 

不要求釋放許可的線程必須通過調用 acquire() 來擷取許可。通過應用程式中的編程約定來建立訊號量的正確用法。

 

相關例子:

 

下面的例子只允許5個線程同時進入執行acquire()和release()之間的代碼:

public class SemaphoreTest {     public static void main(String[] args) {          // 線程池         ExecutorService exec = Executors.newCachedThreadPool();          // 只能5個線程同時訪問         final Semaphore semp = new Semaphore(5);          // 類比20個用戶端訪問         for (int index = 0; index < 20; index++) {            final int NO = index;              Runnable run = new Runnable() {                  public void run() {                      try {                          // 擷取許可                         semp.acquire();                          System.out.println("Accessing: " + NO);                          Thread.sleep((long) (Math.random() * 10000));                          // 訪問完後,釋放 ,如果屏蔽下面的語句,則在控制台只能列印5條記錄,之後線程一直阻塞                        semp.release();                      } catch (InterruptedException e) {                      }                  }              };              exec.execute(run);          }          // 退出線程池         exec.shutdown();      }  }

 

 

Java之多線程 Semaphore(訊號量)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.