• <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>

            martin

            thinking

            常用鏈接

            統計

            software

            最新評論

            mutex與semaphore的區別

            "互斥(mutext)和旗語(semaphore)之間有什么不同?"這樣的問題簡短而有力,但要回答卻相當困難.即使有經驗的實時操作系統(RTOS)用戶在區別如何正確使用mutex和semaphore時也存在著困難.
            但這一點很不幸而且很危險,因為無任這兩種原生RTOS中的哪一種被錯誤使用,都會導致嵌入式系統出現意想不到的錯誤,特別是這些系統為有關生命安全的產品時.
            有關mutex和semaphore的荒誕說法是它們是相似的,甚至是可以互換的.正確的事實是盡管mutex和semaphore在它們的執行上有相似之處,但是我們還是應該在使用它們時加以區別對待.
            最普遍(但也是不正確)的答案是:mutex和semphore非常相似,它們只有一個區別,那就是semaphores的計數可以超過1. 差不多所有的工程師都能正確的理解:mutex是一個二進制標志,可以通過它來確保執行流在代碼關鍵區(critical section of code)互相排斥,從而對共享資源加一保護.但當他們被要求進一步回答如何使用"計算方法semaphore"的方式時,大部分工程師的回答就如同教科書書一般的刻板---semaphore用于保護多重同類資源.
            通過類比辦法,我們很容易解釋為什么"多重資源"場景是有缺陷的.如果你認為一個mutex是由操作系統擁有的關鍵值的話,我們可以很容易地將個別的mutex比喻是城市咖啡店中一間浴室的鑰匙.如果你想使用浴室,卻找不到鑰匙,你就必須在一個隊列中等候.同樣地,mutex則協串行化多項任務,以取得全域資源的共享,并且為等待隊列中的任務分配一個靜候其循序漸進的位置.
            但這種簡單的資源保護協議并不使用于兩間相同浴室的情況.如果把一個semaphore概括為一個mutex,使其能保護兩個或更多相同的資源,那么在我們的比喻中,它就象是放著兩把相同鑰匙的藍子,你可以用任何一把打開任何一扇浴室的門.
            因此,semaphore本身并不能解決多個相同資源的問題.咖啡店中的客人可能只知道有一把鑰匙,但并不知道哪間浴室可用.如果你試圖以此方式使用semaphore,你將會發現需要更多的狀態信息---它們通常是由不同的mutex所保護的共享資源.
            正確使用semaphore是為了使信號從一項任務傳至另一項任務.mutex意味著取得與釋放,使用受保護共享資源的每一次任務都是以這樣的順序進行.相比之下,使用semaphore的任務通常不是發送信號,就是進入等待狀態,不可能同時發生.
            例如,任務1可能包含程序代碼,當按下"電源"(power)按鈕時,即可提出(如發送信號或增量)一個特別的semaphore; 任務2則依據相同的semaphore而用于喚醒顯示器. 在這種情況下,其中一項任務是信號的生產者,另一項任務是信號的消費者.

            用一個例子來做總結,首先展示如何使用mutex:
            /* Task 1 */
            mutexWait(mutex_mens_room);
            // Safely use shared resource
            mutexRelease(mutex_mens_room);

            /* Task 2 */
            mutexWait(mutex_mens_room);
            // Safely use shared resource
            mutexRelease(mutex_mens_room);

            相應地,你總是采用下列方法使用semaphore:
            /* Task 1 - Producer */
            semPost(sem_power_btn); // Send the signal

            /* Task 2 - Consumer */
            semPend(sem_power_btn); // Wait for signal

            重要的是,semaphores可以被interrupt service routine(ISR)中斷服務程序用來向task發送信號.發送一個semaphore是一個非阻塞的RTOS行為,并且ISR安全.因為這種技術排除了在task級別的為了是中斷不使能而引起的錯誤的可能性,從ISR中發出信號是一種使嵌入式軟件更加可靠的設計方式.

            http://www.embedded.com/columns/guest/210605040?printable=true
            http://www.eettaiwan.com/ART_8800557420_676964_NT_a22f6436.HTM

            posted on 2009-03-18 15:37 martin_yahoo 閱讀(22069) 評論(4)  編輯 收藏 引用

            評論

            # re: mutex與semaphore的區別 2009-03-18 21:13 everspring79

            信號量可以設置計數器,而互斥鎖只有0和1的關系。
            這樣的說法其實也沒有錯,從應用角度完全可以引申出更多的內容。
            另外,vxworks中sem_take()的用法似乎和你所舉的例子 mutextWait有類似之處。  回復  更多評論   

            # re: mutex與semaphore的區別 2009-03-19 10:45 kevin.c

            一個是內核對象,一個是應用層API  回復  更多評論   

            # re: mutex與semaphore的區別 2009-06-03 13:41 heng

            信號量可以設置計數器,而互斥鎖只有0和1的關系
            一個是內核對象,一個是應用層API

            很經典  回復  更多評論   

            # re: mutex與semaphore的區別[未登錄] 2011-09-18 22:12 bin

            "如果把一個semaphore概括為一個mutex,使其能保護兩個或更多相同的資源,那么在我們的比喻中,它就象是放著兩把相同鑰匙的藍子,你可以用任何一把打開任何一扇浴室的門.
            因此,semaphore本身并不能解決多個相同資源的問題.咖啡店中的客人可能只知道有一把鑰匙,但并不知道哪間浴室可用."

            這個比喻有問題,實際上semaphore保護的是鑰匙,而不是浴室,兩把不同的鑰匙已經不是相同的資源!  回復  更多評論   

            久久综合中文字幕| 久久天堂AV综合合色蜜桃网| 久久不射电影网| 久久免费线看线看| 久久精品国产一区二区电影| 色欲综合久久躁天天躁| 国产精品久久久福利| 99久久婷婷国产综合精品草原| 久久无码人妻精品一区二区三区| 最新久久免费视频| 2020最新久久久视精品爱| 狠狠色丁香久久婷婷综合图片| 久久久精品2019免费观看| 久久精品国产亚洲精品| 成人国内精品久久久久影院| 久久婷婷色综合一区二区| 国产精品一久久香蕉国产线看观看 | 93精91精品国产综合久久香蕉 | 久久激情亚洲精品无码?V| 狠狠色丁香久久婷婷综合五月| 久久亚洲色一区二区三区| 久久精品www人人爽人人| 伊人久久亚洲综合影院| 国内精品免费久久影院| 久久丫精品国产亚洲av不卡| 一级做a爰片久久毛片看看 | 久久久亚洲裙底偷窥综合| 国产AⅤ精品一区二区三区久久| 亚洲香蕉网久久综合影视| 久久久久亚洲AV无码专区桃色| 99久久婷婷免费国产综合精品| 久久婷婷国产剧情内射白浆 | 久久中文字幕人妻熟av女| 2020最新久久久视精品爱| 粉嫩小泬无遮挡久久久久久| 2021国产精品久久精品| 伊人 久久 精品| 亚洲狠狠婷婷综合久久久久| 久久国产劲爆AV内射—百度| 欧美伊人久久大香线蕉综合| 久久久久亚洲av成人无码电影 |