管理幾個線程并不是真正的難題,對于上百個線程它是怎樣管理的呢?當然可以通過循環,來執行每一個線程,但是這顯然是冗長、乏味。JAVA創建了線程組。線程組是線程的一個譜系組,每個組包含的線程數不受限制,能對每個線程命名并能在整個線程組中執行(Suspend)和停止(Stop)這樣的操作。
2.4信號標志:保護其它共享資源
這種類型的保護被稱為互斥鎖。某個時間只能有一個線程讀取或修改這個數據值。在對文件尤其是信息數據庫進行處理時,讀取的數據總是多于寫數據,根據這個情況,可以簡化程序。下面舉一例,假設有一個雇員信息的數據庫,其中包括雇員的地址和電話號碼等信息,有時要進行修改,但要更多的還是讀數據,因此要盡可能防止數據被破壞或任意刪改。我們引入前面互斥鎖的概念,允許一個讀取鎖(red lock)和寫入鎖(write lock),可根據需要確定有權讀取數據的人員,而且當某人要寫數據時,必須有互斥鎖,這就是信號標志的概念。信號標志有兩種狀態,首先是empty()狀態,表示沒有任何線程正在讀或寫,可以接受讀和寫的請求,并且立即提供服務;第二種狀態是reading()狀態,表示有線程正在從數據庫中讀信息,并記錄進行讀操作的線程數,當它為0時,返回empty狀態,一個寫請求將導致這個線程進入等待狀態。
只能從empty狀態進入writing狀態,一旦進入writing狀態后,其它線程都不能寫操作,任何寫或讀請求都必須等到這個線程完成寫操作為止,而且waiting狀態中的進程也必須一直等到寫操作結束。完成操作后,返回到empty狀態,發送一個通知信號,等待的線程將得到服務。
下面實現了這個信號標志
class Semaphore{
final static int EMPTY=0;
文章來源于領測軟件測試網 http://www.kjueaiud.com/