在windows下:
信號量(Semaphore)內(nèi)核對象對線程的同步方式,它允許多個線程在同一時刻訪問同一資源,但是需要限制在同一時刻訪問此資源的最大線程數(shù)目。
CreateSemaphore()
OpenSemaphore()
ReleaseSemaphore(),
WaitForSingleObject()/WaitForMultipleObjects()
CreateSemaphore()創(chuàng)建信號量時即要同時指出允許的最大資源計數(shù)和當(dāng)前可用資源計數(shù)。
一般是將當(dāng)前可用資源計數(shù)設(shè)置為最大資源計數(shù),
每增加一個線程對共享資源的訪問,當(dāng)前可用資源計數(shù)就會減1,
只要當(dāng)前可用資源計數(shù)是大于0的,就可以發(fā)出信號量信號。
但是當(dāng)前可用計數(shù)減小到0時則說明當(dāng)前占用資源的線程數(shù)已經(jīng)達(dá)到了所允許的最大數(shù)目,不能在允許其他線程的進(jìn)入,此時的信號量信號將無法發(fā)出。
線程在處理完共享資源后,應(yīng)在離開的同時通過ReleaseSemaphore()函數(shù)將當(dāng)前可用資源計數(shù)加1。在任何時候當(dāng)前可用資源計數(shù)決不可能大于最大資源計數(shù)。
說明如下:
HANDLE CreateSemaphore(
LPSECURITY_ATTRIBUTES lpSemaphoreAttributes, // 安全屬性指針
LONG lInitialCount, // 初始計數(shù)
LONG lMaximumCount, // 最大計數(shù), 定義了允許的最大資源計數(shù)
LPCTSTR lpName // 對象名指針, 創(chuàng)建的信號量定義一個名字,其創(chuàng)建的是一個內(nèi)核對象,因此在其他進(jìn)程中可以通過該名字而得到此信號量
);
OpenSemaphore()函數(shù)即可用來根據(jù)信號量名打開在其他進(jìn)程中創(chuàng)建的信號量,函數(shù)原型如下:
HANDLE OpenSemaphore(
DWORD dwDesiredAccess, // 訪問標(biāo)志
BOOL bInheritHandle, // 繼承標(biāo)志
LPCTSTR lpName // 信號量名
);
在線程離開對共享資源的處理時,通過ReleaseSemaphore()來增加當(dāng)前可用資源計數(shù)。否則將會出現(xiàn)當(dāng)前正在處理共享資源的實(shí)際線程數(shù)并沒有達(dá)到要限制的數(shù)值,
而其他線程卻因為當(dāng)前可用資源計數(shù)為0而仍無法進(jìn)入的情況。
BOOL ReleaseSemaphore(
HANDLE hSemaphore, // 信號量句柄
LONG lReleaseCount, // 計數(shù)遞增數(shù)量
LPLONG lpPreviousCount // 先前計數(shù),可以設(shè)置為NULL,
);
該函數(shù)將lReleaseCount中的值添加給信號量的當(dāng)前資源計數(shù),一般將lReleaseCount設(shè)置為1,
WaitForSingleObject和WaitForMultipleObjects主要用在試圖進(jìn)入共享資源的線程函數(shù)入口處,
主要用來判斷信號量的當(dāng)前可用資源計數(shù)是否允許本線程的進(jìn)入。
只有在當(dāng)前可用資源計數(shù)值大于0時,被監(jiān)視的信號量內(nèi)核對象才會得到通知。