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

            CppExplore

            一切像霧像雨又像風

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              29 隨筆 :: 0 文章 :: 280 評論 :: 0 Trackbacks

            作者:CppExplore  http://www.shnenglu.com/CppExplore/http://blog.csdn.net/cppexplore同步發布

            一 semaphore機制
            古老的信號量機制,80年代初,從System V體系中產生,稱為System v信號量。90年代,Posix標準確立,其中的信號量稱為posix信號量。當前linux系統支持這兩種信號量(man semget/ man sem_post)。System v信號量為有名信號量,可以用于多進程間的互斥同步。posix信號量分有名和無名兩種,當前linux只支持無名信號量,可以用于多線程之間的互斥同步,通過共享內存也可以用于多進程之間。
            信號量屬于內核級別的互斥同步機制,相關調用總是陷入內核態,屬于功能強大/重量級的實現。

            二 spinlock機制
            多核SMP的cpu流行后,出現的新的互斥同步機制。spinlock實現原理為用戶態循環嘗試機制,不陷入內核態進行線程切換。spinlock的原子性通過CAS(CompareAndSwap)原語實現。使用spinlock時,應該保證保護區間內代碼執行迅速,不應該存在io等耗時操作。
            多核系統下,針對可快速執行的保護區使用用戶態循環嘗試機制,可以保證執行線程不需要引起上下文切換即可快速執行通過,這種機制也被形象的稱為lock-free機制。我們可以這樣理解:lock-free機制即為循環嘗試,spinlock是它的具體實現。

            spinlock的實現有多種,常見的有pthread_spin_lock,該spinlock無限制循環嘗試,在多核環境下并且保護區代碼執行迅速時,執行線程很快可以拿到鎖,但當單核環境或者保護區代碼執行慢速時,則會耗盡該線程擁有的時間片之后交出cpu,造成cpu的浪費。另一常見的spinlock是boost智能指針中的實現,進行3次無間斷的循環CAS原語判斷,之后若再次失敗,則調用sleep族函數,交出cpu執行權,待再次分配到cpu時間片后繼續進行CAS原語判斷操作。


            三 mutex機制
            mutex屬于os之上的再次封裝實現。在linux2.6內核上,線程庫為nptl,其中的mutex基于futex機制實現,它的實現原理,簡單說就是spinlock+semaphore,首先使用spinlock嘗試,可以拿到鎖則直接向下執行,拿不到鎖則執行semaphore機制,陷入內核態,進入線程切換。
            在多核環境下,當mutex保護的代碼段內無io操作,執行很快時,大多數情況下通過spinlock都可拿到鎖,不需要陷入內核態。


            四 為智能指針正名(boost)
            智能指針的引用計數僅僅為一個整型變量的增減,屬于執行迅速的典型,使用spinlock機制保護,最新boost版本中僅僅是spinlock,而非mutex。從性能角度說,使用智能指針的現象是cpu略微上升(循環嘗試導致),而并發量/單個請求的響應時間并無明顯影響。proactor機制實現的網絡層,智能指針基本無法繞過,刻意避免帶來的只能是丑陋的代碼和維護量的上升。但線程之間盡量避免傳遞指針(智能指針),通過傳遞id等代替。
            智能指針有它使用的場景,不能濫用,也不能刻意避免。

            posted on 2010-08-28 18:22 cppexplore 閱讀(4333) 評論(12)  編輯 收藏 引用

            評論

            # re: 【原創】從同步互斥機制到智能指針使用成本 2010-08-31 02:08 trueOO
            這才叫文章啊。??纯词醉撋隙际切┦裁赐嬉獍?nbsp; 回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 [未登錄] 2010-09-01 19:03 Sea
            同意
              回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 2010-09-02 16:44 金慶
            "線程之間盡量避免傳遞指針"? 能說明一下嗎?傳id和傳指針有什么區別?  回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 [未登錄] 2010-09-04 11:16 cppexplore
            @金慶
            線程之間傳遞指針,基本就是傳遞智能指針。
            傳遞id代替就是為了避免智能指針  回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 2010-09-10 17:15 Markin
            博主真乃超級技術達人,期待更多更好的技術貼,學習ing  回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 2010-09-25 18:08 xwb
            博主威武! 望塵莫及...@Markin
              回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 [未登錄] 2010-12-24 15:11 vincent
            膜了個拜 啊  回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 2011-03-24 14:50 egmkang
            據說mutex在沒有io的時候也是通過spinlock來實現互斥的.  回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 2011-03-24 14:51 egmkang
            當我沒說,我轉了一圈轉回來了..  回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 2011-03-28 12:45 cppexplore
            @egmkang
            :)  回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 2011-06-05 08:27 Batiliu
            引用:proactor機制實現的網絡層,智能指針基本無法繞過,刻意避免帶來的只能是丑陋的代碼和維護量的上升。

            LZ強人。本人在IOCP基礎上實現proactorIO模型時,被資源釋放困擾了N久,最后還是智能指針解的困,但現在還不夠完美。

            其他LZ談談相關的具體方案或心得,epoll也好iocp也好。  回復  更多評論
              

            # re: 【原創】從同步互斥機制到智能指針使用成本 [未登錄] 2011-07-14 22:25 kevin
            @金慶
            指針指向的內存地址可能無效。  回復  更多評論
              

            久久久国产精品| 久久无码人妻一区二区三区午夜| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 青青草原综合久久大伊人精品| 国产精品成人99久久久久91gav| 亚洲精品午夜国产va久久| 色欲久久久天天天综合网| 国产精品欧美久久久久天天影视 | 久久最新免费视频| 精品国产一区二区三区久久久狼| 久久99精品九九九久久婷婷 | 久久精品成人一区二区三区| 99久久国产精品免费一区二区| 99精品国产在热久久无毒不卡| 国内精品伊人久久久影院| 精品国产乱码久久久久久浪潮| 伊人色综合久久天天人手人婷| 久久久人妻精品无码一区| 久久精品国产99国产电影网 | 久久婷婷五月综合成人D啪| 99久久人妻无码精品系列| 久久中文字幕人妻丝袜| 人人狠狠综合久久亚洲| 久久久国产一区二区三区| 国产精品欧美亚洲韩国日本久久| 99久久99这里只有免费费精品| 久久一日本道色综合久久| 97精品依人久久久大香线蕉97| 亚洲国产精品一区二区三区久久 | 合区精品久久久中文字幕一区| 国产精品伊人久久伊人电影 | AA级片免费看视频久久| 久久国产精品-国产精品| 久久婷婷久久一区二区三区| 99久久无色码中文字幕| 久久精品人人做人人爽97| 国产V综合V亚洲欧美久久| 久久精品国产免费一区| 日韩精品久久久久久| 欧洲性大片xxxxx久久久| 亚洲人成无码网站久久99热国产|