• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            sherrylso

            C++博客 首頁 新隨筆 聯系 聚合 管理
              18 Posts :: 0 Stories :: 124 Comments :: 0 Trackbacks

                   在windows平臺下,用于對多線程(包括進程)之間的同步保護機制,基本上有這么幾種:
            1)Critical Section對象 2)Event對象 3)Mutex對象 4) Semaphore對象。網上已經有很多的文章在介紹這些對象是怎么使用的。本文的著眼點在于:總結出這些同步保護機制的一些明顯的行為特征,而這些行為特征,也是我們再寫程序時經常會碰到的。

                   以下我們所討論的這些行為特征,是對并發的進/線程之間的同步保護機制的一般描述,本文用windows平臺作為一個典型的例子。 基于這一些行為特征,對本文提及的這四種同步對象做一個分類。
            另外,在這里,我們把這四種同步對象,統統稱為“鎖”,以便于接下來的討論。
            第一、保護與同步。
                    在這里要強調的是:保護與同步是兩個不同的概念。而我們經常會混合這兩個概念。保護是指在多線程的環境下對共享資源的保護。這樣的共享資源大多數情況下是一段內存塊,它會被很多線程試圖訪問和修改。而同步更多的強調的是線程之間的協作,協同工作是需要同步支持的。
            基于這一性質,我們可以看出:Critical Section對象其本質更多的強調的是保護,而Event對象、Mutex對象與Semaphore對象更多的強調的是同步。不過,這樣的區別,只是概念上的區別,其本身不會對程序本身產生影響。
            第二、鎖的等待超時
                   在開發并發的多進/線程程序時,為了避免死鎖之類的問題,引入了“等超時“的概念,即當一個線程需要獲得一個鎖來執行某些代碼的時候,它可以在所等待的鎖上設置超時值。如果在確定的時間(超時值)內無法獲得該鎖,它可以選擇放棄執行該段代碼的權利,這樣可以在一定程度上避免出現死鎖的問題。這就是鎖的等待超時的基本含義。基于這一行為特征,我們來對上面四種同步對象做一個劃分:Critical Section對象是無法設置等待超時的,而其他三個對象則可以設置等待超時。從這一點來講,在使用Critical Section對象時,由于在等待進入關鍵代碼段時無法設置等待超時,很容易造成死鎖。
            第三、線程鎖與進程鎖
                    這里所說的線程鎖指的是該鎖只在一個進程的所有線程中可見,而進程鎖指的是該鎖可以被不同的進程所訪問,可用于進程間的同步與互斥。當然進程鎖仍然可以被用于同一個進程的不同線程之間的同步與互斥。進程鎖的概念是大于線程鎖的。基于這一特點劃分的話,Critical Section對象是線程鎖,而其他三個對象是進程鎖。這一點從本質上來分析,Critical Section對象是用戶態模式下面實現線程同步的方法,而其他三個對象均是內核對象。內核對象機制的適應性遠遠優于用戶方式機制。實際上,內核對象機制的唯一不足之處在于它的速度比較慢,這是因為當調用內核機制對象時,必須從用戶方式轉到內核方式。這樣的轉換需要付出很大的代價,是一件很費時的操作。在X86平臺上,這樣往返一次需要占用1000個CPU周期(這并不包括執行內核方式的代碼)。當然需要注意的是:使用Critical Section對象并不意味著線程不會陷入核心態執行。當一個線程試圖進入另一個線程擁有的關鍵代碼段時,該線程就會進入等待狀態。這意味著:該線程必須從用戶態轉為核心態。(為了提高這一方面的性能,Microsoft將循環鎖的概念納入到了Critical Section對象中,該線程可以有選擇地不進入核心態等待.具體請參閱MSDN)
            第四、鎖的遞歸特質
                    所謂遞歸鎖指的是當一個線程擁有一個同步鎖時,而遞歸地想再次取得該鎖.如果這次獲得操作不會阻塞當前線程的執行,則稱該鎖為遞歸鎖.遞歸鎖主要是在"保護"的概念上提出的,而"保護"概念下的鎖包括Critical Section對象和Mutext 對象.這兩種鎖在Windows平臺上都是遞歸鎖。需要注意的是:調用線程獲得幾次遞歸鎖必須釋放幾次遞歸鎖。
            第五、讀寫鎖
                   讀寫鎖允許高效的并發的訪問多線程環境下的共享資源。對于一種共享資源,多個線程可以獲得讀鎖,共享地讀該共享資源。而在同一時刻,只允許一個線程擁有寫鎖改變該共享資源.這就是讀寫鎖的概念。很遺憾的是在Windows平臺上沒有這樣的讀寫鎖,你需要自己去實現。
            對以上總結如圖:


            Futher Read:
                     個人認為,如果你想深入研究多線程的同步機制,ACE是一個絕佳的教材,在這里,你會看到什么是Scoped Lock, 讀寫鎖如何實現等等。

            posted on 2007-07-22 21:10 愛上龍卷風 閱讀(4905) 評論(6)  編輯 收藏 引用

            Feedback

            # re: windows同步對象小結 2007-07-22 22:40 pass86
            恩,正在看ACE,不過發現BOOST的的同步機制也不錯。  回復  更多評論
              

            # re: windows同步對象小結 2007-07-22 22:43 pass86
            ACE的很期待。  回復  更多評論
              

            # re: windows同步對象小結 2008-09-19 13:38 wangwj
            這篇是我看到同步對象最好的總結文檔,謝謝博主的好文章。  回復  更多評論
              

            # re: windows同步對象小結 2009-02-18 14:06 lin_style
            不錯。。找了半天終于找到個有用的了  回復  更多評論
              

            # re: windows同步對象小結 2010-02-10 19:30 XX
            翻譯得非常好!贊一個  回復  更多評論
              

            # re: windows同步對象小結 2013-12-12 16:51 紅色代碼
            寫的很好。謝謝  回復  更多評論
              

            97久久超碰成人精品网站| 久久天天躁狠狠躁夜夜avapp | 亚洲天堂久久精品| 大美女久久久久久j久久| 四虎国产精品免费久久| 久久久久亚洲AV成人网人人网站 | 三级三级久久三级久久 | 一级做a爰片久久毛片16| 国产精品成人无码久久久久久| 久久久久久久久久久免费精品| 久久久久波多野结衣高潮| 日本一区精品久久久久影院| 久久这里有精品| 国产高潮国产高潮久久久91 | 国产精品一区二区久久精品无码 | 久久精品天天中文字幕人妻| 久久99精品九九九久久婷婷| 久久久久成人精品无码中文字幕| 一级做a爰片久久毛片16| 亚洲中文字幕久久精品无码喷水 | 久久96国产精品久久久| 久久天天躁狠狠躁夜夜不卡| 爱做久久久久久| 日本精品久久久久中文字幕| 一本一本久久A久久综合精品| 亚洲国产香蕉人人爽成AV片久久 | 国产精品久久久久久福利漫画| 久久受www免费人成_看片中文| 国产精品成人久久久久三级午夜电影 | 久久久久久国产精品免费免费| 久久精品国内一区二区三区| 亚洲国产精品高清久久久| 2019久久久高清456| 亚洲欧美日韩久久精品| 欧洲性大片xxxxx久久久| www亚洲欲色成人久久精品| 国产成人99久久亚洲综合精品| 久久国产精品一区二区| 久久这里只精品国产99热| 日本精品久久久久中文字幕| 88久久精品无码一区二区毛片 |