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

            Error

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

            網上很容易找到一個用boost::shared_mutex來作為讀寫鎖的例子:

            1. typedef boost::shared_mutex rwmutex;  
            2. typedef boost::shared_lock<rwmutex> readLock;  
            3. typedef boost::unique_lock<rwmutex> writeLock;   

             

            一直沒有懷疑過這個做法,直到最近項目中出現一個死鎖問題,查了很久才發現是上面這種寫法造成的。

            寫測試代碼還原死鎖的情景如下:

            1. #include <boost/thread/shared_mutex.hpp>   
            2. #include <boost/thread/shared_lock_guard.hpp>   
            3. #include <boost/thread.hpp>   
            4. #include <iostream>   
            5. #include <Windows.h>   
            6. using namespace std;  
            7. typedef boost::shared_mutex rwmutex;  
            8. typedef boost::shared_lock<rwmutex> readLock;  
            9. typedef boost::unique_lock<rwmutex> writeLock;  
            10.   
            11. rwmutex m_mutex;  
            12. void func1()  
            13. {  
            14.     writeLock lock1(m_mutex);  
            15.     cout << "fffffffffffffff" << endl;  
            16. }  
            17.   
            18. int main()  
            19. {  
            20.     {  
            21.         boost::thread tt(func1);  
            22.         readLock lock(m_mutex); // 加讀鎖   
            23.         {  
            24.             Sleep(3000);  // 故意睡眠3秒將線程切換出去   
            25.             readLock lock(m_mutex); // 醒來后再次加讀鎖   
            26.             cout << "rrrrrrrrrrrrrrrrrr" << endl;  
            27.         }  
            28.     }  
            29. }  

            情形描述如下:

            1:主線程先給m_mutex加讀鎖。

            2:主線程故意睡眠3秒將執行權限切換出去。

            3:func1線程獲得執行機會,嘗試加寫鎖被掛起。因為主線程已經有一個讀鎖占用,寫鎖必須等待這個讀鎖釋放才能進入。

            4:主線程睡眠3秒醒來,后續代碼想獲取一個讀鎖。由于這個時候已經有一個寫鎖在等待進入,那么這個讀鎖排隊在寫鎖后面,同樣被掛起。

            5:主線程和func1線程都被掛起了,發生死鎖。

            上面的測試代碼,如果中間沒有sleep(3000),出現死鎖的概率很低,但總歸是存在死鎖的可能。

             

            總結:

            以前一直認為readLock鎖和遞歸鎖一樣,在同一個線程多次進入沒有關系才會造成上面的死鎖出現。所以,boost::shared_lock使用要小心,千萬不要同一個線程多次進入。

            posted on 2013-01-31 18:46 Enic 閱讀(1576) 評論(0)  編輯 收藏 引用 所屬分類: about boost
            久久精品国产色蜜蜜麻豆| 亚洲AV无一区二区三区久久| 久久99精品久久久久子伦| 久久精品国产亚洲一区二区| 久久久精品人妻一区二区三区四| 国产美女亚洲精品久久久综合| 一本色道久久HEZYO无码| A级毛片无码久久精品免费| 亚洲精品国产综合久久一线| 蜜臀av性久久久久蜜臀aⅴ麻豆| 久久精品国产精品亚洲精品| 久久九九久精品国产免费直播| 亚洲精品97久久中文字幕无码| 91精品国产高清久久久久久io| 久久无码精品一区二区三区| 国内精品久久久久影院日本 | 国内精品久久久久久久coent| 伊人色综合久久天天网| 久久99国产一区二区三区| 嫩草伊人久久精品少妇AV| 老男人久久青草av高清| 一日本道伊人久久综合影| 久久成人小视频| 欧美丰满熟妇BBB久久久| 久久久久亚洲精品无码蜜桃| 欧美大香线蕉线伊人久久| 99麻豆久久久国产精品免费| 97精品伊人久久久大香线蕉| 91精品婷婷国产综合久久| 亚洲国产精品人久久| 午夜精品久久久久成人| 亚洲女久久久噜噜噜熟女| 国产精品美女久久久久| 久久伊人精品青青草原日本| 亚洲人成网站999久久久综合| 久久久久久精品久久久久| 国产99精品久久| 一本大道久久东京热无码AV| 国产成年无码久久久久毛片| 一级a性色生活片久久无少妇一级婬片免费放 | 国产精品一久久香蕉国产线看观看 |