關於windows的進程處理(八)

Critical Section、Mutex、Semaphore、Event幾種線程控制方法對比說明:數據庫

查詢了一下以爲http://blog.csdn.net/wind19/article/details/7520860文章已經寫的很是細緻了,因而摘錄了一些主要內容以下,若是想看原文,能夠直接查看原文便可。安全

臨界區(Critical Section)
    保證在某一時刻只有一個線程能訪問數據的簡便辦法。在任意時刻只容許一個線程對共享資源進行訪問。若是有多個線程試圖同時訪問臨界區,那麼在有一個線程進 入後其餘全部試圖訪問此臨界區的線程將被掛起,並一直持續到進入臨界區的線程離開。臨界區在被釋放後,其餘線程能夠繼續搶佔,並以此達到用原子方式操做共 享資源的目的。
互斥量(Mutex)
   互斥(Mutex)是一種用途很是普遍的內核對象。可以保證多個線程對同一共享資源的互斥訪問。同臨界區有些相似,只有擁有互斥對象的線程才具備訪問資源 的權限,因爲互斥對象只有一個,所以就決定了任何狀況下此共享資源都不會同時被多個線程所訪問。當前佔據資源的線程在任務處理完後應將擁有的互斥對象交 出,以便其餘線程在得到後得以訪問資源。與其餘幾種內核對象不一樣,互斥對象在操做系統中擁有特殊代碼,並由操做系統來管理,操做系統甚至還容許其進行一些 其餘內核對象所不能進行的很是規操做。 互斥量跟臨界區很類似,只有擁有互斥對象的線程才具備訪問資源的權限,因爲互斥對象只有一個,所以就決定了任何狀況下此共享資源都不會同時被多個線程所訪 問。當前佔據資源的線程在任務處理完後應將擁有的互斥對象交出,以便其餘線程在得到後得以訪問資源。互斥量比臨界區複雜。由於使用互斥不只僅可以在同一應 用程序不一樣線程中實現資源的安全共享,並且能夠在不一樣應用程序的線程之間實現對資源的安全共享。
信號量(Semaphores)
    信號量對象對線程的同步方式與前面幾種方法不一樣,信號容許多個線程同時使用共享資源,這與操做系統中的PV操做相同。它指出了同時訪問共享資源的線程最大 數目。它容許多個線程在同一時刻訪問同一資源,可是須要限制在同一時刻訪問此資源的最大線程數目。在用CreateSemaphore()建立信號量時即 要同時指出容許的最大資源計數和當前可用資源計數。通常是將當前可用資源計數設置爲最大資源計數,每增長一個線程對共享資源的訪問,當前可用資源計數就會 減1,只要當前可用資源計數是大於0的,就能夠發出信號量信號。可是當前可用計數減少到0時則說明當前佔用資源的線程數已經達到了所容許的最大數目,不能 在容許其餘線程的進入,此時的信號量信號將沒法發出。線程在處理完共享資源後,應在離開的同時經過ReleaseSemaphore()函數將當前可用資 源計數加1。在任什麼時候候當前可用資源計數決不可能大於最大資源計數。 信號量是經過計數來對線程訪問資源進行控制的,而實際上信號量確實也被稱做Dijkstra計數器。
事件(Event)
    事件對象也能夠經過通知操做的方式來保持線程的同步。而且能夠實現不一樣進程中的線程同步操做。
    使用臨界區只能同步同一進程中的線程,而使用事件內核對象則能夠對進程外的線程進行同步,其前提是獲得對此事件對象的訪問權。
總結:併發

    1. 互斥量與臨界區的做用很是類似,但互斥量是能夠命名的,也就是說它能夠跨越進程使用。因此建立互斥量須要的資源更多,因此若是隻爲了在進程內部是用的話使 用臨界區會帶來速度上的優點並可以減小資源佔用量。由於互斥量是跨進程的互斥量一旦被建立,就能夠經過名字打開它。函數

    2. 互斥量(Mutex),信號燈(Semaphore),事件(Event)均可以被跨越進程使用來進行同步數據操做,而其餘的對象與數據同步操做無關,但 對於進程和線程來說,若是進程和線程在運行狀態則爲無信號狀態,在退出後爲有信號狀態。因此可使用WaitForSingleObject來等待進程和 線程退出。操作系統

    3. 經過互斥量能夠指定資源被獨佔的方式使用,但若是有下面一種狀況經過互斥量就沒法處理,好比如今一位用戶購買了一份三個併發訪問許可的數據庫系統,能夠根 據用戶購買的訪問許可數量來決定有多少個線程/進程能同時進行數據庫操做,這時候若是利用互斥量就沒有辦法完成這個要求,信號燈對象能夠說是一種資源計數 器。.net

相關文章
相關標籤/搜索