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

            為生存而奔跑

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              271 Posts :: 0 Stories :: 58 Comments :: 0 Trackbacks

            留言簿(5)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 330187
            • 排名 - 74

            最新評論

            閱讀排行榜

            評論排行榜

            考慮下面的代碼:
            vector<int>v;

            vector
            <int>::iterator first5(find(v.begin(),v.end(),5)); // ..(1)
            if(first5!=v.end())                                      // ..(2)
               doSomething();


            假如在多線程環境中,當語句執行到第(1)句時,另一個線程可能會奪取CPU的控制權并且改變v的值,比如往v里面插入一些元素。這樣v的所有的迭代器都將失效,包括first5.

            要做到線程安全,必須從第1句到第3句保持鎖住狀態。
            可以定義一個Lock類
            template<typename Container>
            class Lock
            {
            public:
                Lock(
            const Container & container):c(container)
                {
                    getMutexFor(c);
                }
                
            ~Lock()
                {
                    releaseMutexFor(c);
                }
            private:
                
            const Container & c;
            };
            使用時:
            vector<int>v;

            {
            Lock
            < vector<int> > Lock(v);
            vector
            <int>::iterator first5(find(v.begin(),v.end(),5)); // ..(1)
            if(first5!=v.end())                                      // ..(2)
               doSomething();
            }
            這樣,當這個代碼段結束時,Lock會調用析構函數,釋放v的互斥鎖。
            這樣實現比如下實現有很多優點:
            vector<int>v;

            getMutexFor(v);
            vector
            <int>::iterator first5(find(v.begin(),v.end(),5)); // ..(1)
            if(first5!=v.end())                                      // ..(2)
               doSomething();
            releaseMutexFor(v);
            1、更好的封裝性
            2、防止releaseMutexFor(v)忘記寫,從而v的互斥鎖沒法釋放
            3、C++保證,如果有異常,局部變量會被析構。所以,即便在我們使用Lock對象時出現異常,互斥鎖依然可以正常釋放。但是如果用下面的實現方式,如果在執行完getMutexFor(v)后出現異常,releaseMutexFor(v)就不會執行了。

            posted on 2009-10-24 20:47 baby-fly 閱讀(1006) 評論(0)  編輯 收藏 引用 所屬分類: Effective STL / C++
            色88久久久久高潮综合影院| 久久午夜夜伦鲁鲁片免费无码影视 | 热re99久久6国产精品免费| 精品久久久久久久久午夜福利| 久久99国产精品二区不卡| 久久精品亚洲精品国产欧美| 中文成人无码精品久久久不卡| 热re99久久精品国99热| 少妇被又大又粗又爽毛片久久黑人 | 日韩精品久久无码人妻中文字幕 | 一本色综合久久| 国产精品久久久久9999高清| 亚洲美日韩Av中文字幕无码久久久妻妇| 亚洲欧美成人综合久久久| 久久伊人中文无码| 伊人久久大香线蕉精品| 久久精品人成免费| 欧美国产成人久久精品| 久久伊人中文无码| 久久精品国产一区二区电影| 狠狠色综合久久久久尤物| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 激情五月综合综合久久69| 国产三级久久久精品麻豆三级| 一本综合久久国产二区| 精品久久综合1区2区3区激情 | 一本色道久久88综合日韩精品 | 久久午夜无码鲁丝片秋霞| 亚洲一区精品伊人久久伊人| 久久本道综合久久伊人| 94久久国产乱子伦精品免费| 狠狠色噜噜狠狠狠狠狠色综合久久| 无码人妻久久一区二区三区免费 | 中文字幕久久精品| 久久影院亚洲一区| 怡红院日本一道日本久久| 精品免费久久久久久久| 精品久久无码中文字幕| 久久99国产精品久久久| 伊人丁香狠狠色综合久久| 久久影视综合亚洲|