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

            常用鏈接

            統(tǒng)計

            software

            最新評論

            C++同步鎖管理的一種方法

            在C++中,通過提供構(gòu)造函數(shù)、析構(gòu)函數(shù)來對處理資源的獲取、釋放。
            通過C++的這種機(jī)制,我們可以很方便地處理C++中的加鎖同步機(jī)制。把鎖對象作為Guard對象的一個成員(m_lock),然后在Guard對象的構(gòu)造中對m_lock進(jìn)行加鎖:m_lock.acquire(),在Guard對象的析構(gòu)函數(shù)中進(jìn)行解鎖:m_lock.release()。先給出代碼實例如下:

            template <class T>
            class Guard
            {
            public :
                    Guard(const T & lock);
                    virtual ~Guard();

            private:
                    const T & m_lock;
            };

            template <class T>
            Guard<T>::Guard(const T & lock) :
                    m_lock(lock)
            {
                    m_lock.acquire();
            }

            template <class T>
            Guard<T>::~Guard()
            {
                    m_lock.release();
            }

            我們可以在應(yīng)用程序中這樣使用它:

             void testFunc(.....)

            {

              Guard<MutexWrapper>  guard(mutex);

              ...

            }

            在剛進(jìn)入函數(shù)testFun(...),創(chuàng)建guard對象,并自動對mutex進(jìn)行加鎖,對特定數(shù)據(jù)(resource)進(jìn)行保護(hù)。當(dāng)應(yīng)用離開testFunc函數(shù)模塊時,根據(jù)guard對象的作用域和生命周期,此時guard對象的析構(gòu)函數(shù)將被調(diào)用,因此將自動對mutex進(jìn)行解鎖。在此之后應(yīng)用的其他線程將可以訪問以前被mutex進(jìn)行保護(hù)起來的資源。

             

            利用上面的方法,我們可以包對資源的同步訪問和訪問控制交給C++的編譯器,而不需要進(jìn)行人工干預(yù),從而減輕應(yīng)用開發(fā)人員的工作負(fù)擔(dān)。

            posted on 2009-03-04 18:11 martin_yahoo 閱讀(4167) 評論(8)  編輯 收藏 引用

            評論

            # re: C++同步鎖管理的一種方法 2009-03-04 20:06 S.l.e!ep.¢%

            template <class T>
            Guard<T>::Guard(const T & lock) :
            m_lock(lock)
            {
            m_lock.acquire(); // 如果這里鎖失敗,繼續(xù)執(zhí)行,然后......
            }  回復(fù)  更多評論   

            # re: C++同步鎖管理的一種方法[未登錄] 2009-03-05 09:35 martin_yahoo

            @S.l.e!ep.¢%

            如果程序在m_lock.acquire()處鎖失敗,則應(yīng)用在此hang住,直到其他線程釋放資源,并被該線程獲取為止.此時這個線程會把資源所定.  回復(fù)  更多評論   

            # re: C++同步鎖管理的一種方法 2009-03-05 12:57 李現(xiàn)民

            這其實是一種很常見的手法  回復(fù)  更多評論   

            # re: C++同步鎖管理的一種方法 2009-03-06 10:38 Matrixcoding

            @martin_yahoo
            人家說的不是hang住,是鎖失敗了,比如內(nèi)存不夠,鎖函數(shù)拋出異常之類的問題~
            另:為什么是const引用,那很多鎖就不使用了~
              回復(fù)  更多評論   

            # re: C++同步鎖管理的一種方法[未登錄] 2009-03-06 13:26 martin_yahoo

            @Matrixcoding
            至于異常處理,那就根據(jù)業(yè)務(wù)的需要進(jìn)行異常處理就可以了.
            至于const引用,就是避免在應(yīng)用中對Guard中的成員m_lock進(jìn)行更改.如果可以進(jìn)行更改,則可能應(yīng)用中多個線程要對同一資源加鎖,可以更改后,可能處理的不是同一個鎖,從而不能對資源進(jìn)行有效地保護(hù).  回復(fù)  更多評論   

            # re: C++同步鎖管理的一種方法 2009-03-06 14:25 Matrixcoding

            @martin_yahoo
            不能對m_llock進(jìn)行更改,如何鎖住?const引用只能調(diào)用m_lock的const成員~  回復(fù)  更多評論   

            # re: C++同步鎖管理的一種方法[未登錄] 2009-03-06 15:48 martin_yahoo

            m_lock 中含有一些成員不能更改,故采用了const修飾,對于加瑣和釋放部分利用mutable修飾.  回復(fù)  更多評論   

            # re: C++同步鎖管理的一種方法 2013-06-08 17:14 tb

            會有異常情況處理嗎  回復(fù)  更多評論   


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            精品久久久久久亚洲精品| 久久午夜夜伦鲁鲁片免费无码影视| 99久久99久久精品国产片果冻| 亚洲AⅤ优女AV综合久久久| 99精品国产综合久久久久五月天| 精品999久久久久久中文字幕| 国产成人久久777777| yy6080久久| 2020最新久久久视精品爱| 久久久久99这里有精品10| 99国产欧美精品久久久蜜芽| 狠狠人妻久久久久久综合| 浪潮AV色综合久久天堂| 四虎国产精品成人免费久久| 久久亚洲国产中v天仙www| 一本色道久久88精品综合| 久久久久无码精品国产app| 99国产欧美久久久精品蜜芽 | 亚洲精品无码成人片久久| 嫩草影院久久99| 国产麻豆精品久久一二三| 日韩欧美亚洲综合久久| 久久久久亚洲av成人无码电影 | 日韩中文久久| 欧美亚洲国产精品久久蜜芽| 久久国产欧美日韩精品| 无码人妻久久一区二区三区免费丨| 欧美亚洲另类久久综合婷婷| 国内精品免费久久影院| 久久精品国产影库免费看| 久久偷看各类wc女厕嘘嘘| 伊人久久大香线蕉av不卡| 久久天天躁狠狠躁夜夜2020一| 久久精品国产亚洲av瑜伽| 精品熟女少妇aⅴ免费久久| 国产精品无码久久四虎| 91亚洲国产成人久久精品网址| 久久婷婷国产麻豆91天堂| 久久午夜电影网| 亚洲国产成人精品女人久久久| 久久久久久噜噜精品免费直播 |