秒杀多线程第八篇 经典线程同步 信号量Semaphore
閱讀本篇之前推薦閱讀以下姊妹篇:
《秒殺多線程第四篇一個經典的多線程同步問題》
《秒殺多線程第五篇經典線程同步關鍵段CS》
《秒殺多線程第六篇經典線程同步事件Event》
《秒殺多線程第七篇經典線程同步互斥量Mutex》
?
前面介紹了關鍵段CS、事件Event、互斥量Mutex在經典線程同步問題中的使用。本篇介紹用信號量Semaphore來解決這個問題。
首先也來看看如何使用信號量,信號量Semaphore常用有三個函數,使用很方便。下面是這幾個函數的原型和使用說明。
第一個?CreateSemaphore
函數功能:創建信號量
函數原型:
HANDLE?CreateSemaphore(
??LPSECURITY_ATTRIBUTES?lpSemaphoreAttributes,
??LONG?lInitialCount,
??LONG?lMaximumCount,
??LPCTSTR?lpName
);
函數說明:
第一個參數表示安全控制,一般直接傳入NULL。
第二個參數表示初始資源數量。
第三個參數表示最大并發數量。
第四個參數表示信號量的名稱,傳入NULL表示匿名信號量。
?
第二個?OpenSemaphore
函數功能:打開信號量
函數原型:
HANDLE?OpenSemaphore(
??DWORD?dwDesiredAccess,
??BOOL?bInheritHandle,
??LPCTSTR?lpName
);
函數說明:
第一個參數表示訪問權限,對一般傳入SEMAPHORE_ALL_ACCESS。詳細解釋可以查看MSDN文檔。
第二個參數表示信號量句柄繼承性,一般傳入TRUE即可。
第三個參數表示名稱,不同進程中的各線程可以通過名稱來確保它們訪問同一個信號量。
?
第三個?ReleaseSemaphore
函數功能:遞增信號量的當前資源計數
函數原型:
BOOL?ReleaseSemaphore(
??HANDLE?hSemaphore,
??LONG?lReleaseCount,??
??LPLONG?lpPreviousCount?
);
函數說明:
第一個參數是信號量的句柄。
第二個參數表示增加個數,必須大于0且不超過最大資源數量。
第三個參數可以用來傳出先前的資源計數,設為NULL表示不需要傳出。
?
注意:當前資源數量大于0,表示信號量處于觸發,等于0表示資源已經耗盡故信號量處于末觸發。在對信號量調用等待函數時,等待函數會檢查信號量的當前資源計數,如果大于0(即信號量處于觸發狀態),減1后返回讓調用線程繼續執行。一個線程可以多次調用等待函數來減小信號量。?
?
最后一個 信號量的清理與銷毀
由于信號量是內核對象,因此使用CloseHandle()就可以完成清理與銷毀了。
?
在經典多線程問題中設置一個信號量和一個關鍵段。用信號量處理主線程與子線程的同步,用關鍵段來處理各子線程間的互斥。詳見代碼:
[cpp]?view plaincopy運行結果如下圖:
可以看出來,信號量也可以解決線程之間的同步問題。
?
由于信號量可以計算資源當前剩余量并根據當前剩余量與零比較來決定信號量是處于觸發狀態或是未觸發狀態,因此信號量的應用范圍相當廣泛。本系列的《秒殺多線程第十篇 生產者消費者問題》將再次使用它來解決線程同步問題,歡迎大家參閱。
?
至此,經典線程同步問題全部結束了,下一篇《秒殺多線程第九篇?經典多線程同步問題總結》將會對其作個總結以梳理各知識點。
?
轉載請標明出處,原文地址:http://blog.csdn.net/morewindows/article/details/7481609
如果覺得本文對您有幫助,請點擊‘頂’支持一下,您的支持是我寫作最大的動力,謝謝。
總結
以上是生活随笔為你收集整理的秒杀多线程第八篇 经典线程同步 信号量Semaphore的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 秒杀多线程第九篇 经典线程同步总结 关键
- 下一篇: 秒杀多线程第十一篇 读者写者问题