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

            LINGSUIYU'S BLOG

            C++博客 聯(lián)系 聚合 管理
              2 Posts :: 0 Stories :: 10 Comments :: 0 Trackbacks

                    在Efficient C++的第二章,講述了關(guān)于繼承和構(gòu)造(析構(gòu))函數(shù)造成的計算開銷,仍然有些糊涂。對與以下三段關(guān)于互斥鎖使用的代碼(來自Efficient c++):

            // Version 1
            int main()
            {
                
                
            // Start timing here
                for(i=0; i<1000000; i++)
                
            {
                    pthread_mutex_lock(
            &mutex);
                    shareCounter
            ++;
                    pthread_mutex_unlock(
            &mutex);
                }

                
            // Stop timing here
                
            }

             

            // Version 2
            int main()
            {
                
                
            // Start timing here
                for(i=0; i<1000000; i++)
                
            {
                    SimpleMutex m(mutex);
                    sharedCounter
            ++;
                }

                
            // Stop timing here
                
            }


            class SimpleMutex
            {
            public:
                SimpleMutex(pthread_mutex_t 
            & lock):myLock(lock){acquire();}
                
            ~SimpleMutex{release();}

            private:
                
            int acquire(){return pthread_mutex_lock(&myLock);}
                
            int release(){return pthread_mutex_unlock(&myLock);}
                pthread_mutex_t 
            & myLock;
            }
            ;

            // Version 3
            int main()
            {
                
                
            // Start timing here
                for(i=0; i<1000000; i++)
                
            {
                    DerivedMutex m(mutex);
                    sharedCounter
            ++;
                }

                
            // Stop timing here
                
            }


            class BaseMutex
            {
            public:
                BaseMutex(pthread_mutex_t 
            & lock){};
                Virtual 
            ~BaseMutex(){};
            }
            ;

            class DerivedMutex:public BaseMutex
            {
            public:
                DerivedMutex(pthread_mutex_t 
            &lock):BaseMutex(lock),myLock(lock){acquire();}
                
            ~DerivedMutex(){release();}

            private:
                
            int acquire(){return pthread_mutex_lock(&myLock);}
                
            int release(){return pthread_mutex_unlock(&myLock);}
                pthread_mutex_t 
            & myLock;
            }
            ;

            書中測得的結(jié)果是Version 1和 Version 2 耗時相同,為1.01s,而Version 3 耗時1.63秒,這說明前兩個版本計算開銷相同而第三個版本計算開銷明顯增加。
                    而書中也說了Version 2 的構(gòu)造函數(shù)中,初始化myLock成員是計算損失,當acquire()內(nèi)聯(lián)不成功的時候,調(diào)用acquire()也是計算損失。
                    再看Version 3,它首先調(diào)用基類的構(gòu)造函數(shù),由于是內(nèi)聯(lián)的,而且函數(shù)體為空,其開銷應(yīng)該忽略不計,然后是初始化myLock,調(diào)用acquire(),這些都跟Version 2中一樣。
                    這樣看起來反倒是Version 2 和  Version 3 的計算花費應(yīng)該相同了,而Version 1的計算花費要比它們少。而書上好像沒有對這個問題作出解釋。我不知道是什么地方理解錯誤了,所以先懸著,等找到答案再把它寫完。或者如有看到此文而不吝賜教的,不勝感激!
            posted on 2008-08-21 10:09 零碎雨 閱讀(661) 評論(3)  編輯 收藏 引用

            Feedback

            # re: 關(guān)于c++繼承帶來的開銷的疑惑 2008-08-22 00:38 theanswerzju
            基類的構(gòu)造函數(shù)明顯不是空的呀 有虛析構(gòu)函數(shù)的 至少還得在構(gòu)造函數(shù)中設(shè)置vtable,vptr的呀  回復(fù)  更多評論
              

            # re: 關(guān)于c++繼承帶來的開銷的疑惑 2008-08-22 08:58 零碎雨
            @theanswerzju
            哦,是的,剛剛學(xué)到vtable和vptr,對c++類的內(nèi)部實現(xiàn)還不是很了解,謝謝您的指出!我仍然有一個疑問,覺得至少Version 2 會比Version 1開銷大一點,因為多了初始化myLock成員,但書上說兩者是一樣的,是不是這個開銷不大可以忽略?  回復(fù)  更多評論
              

            # re: 關(guān)于c++繼承帶來的開銷的疑惑 2008-08-22 17:00 theanswerzju
            @零碎雨
            你可以對比一下兩者的匯編結(jié)果
            記得把inline設(shè)為允許,VC默認Debug下是關(guān)掉的
              回復(fù)  更多評論
              


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


            久久人妻少妇嫩草AV无码蜜桃| 香蕉久久夜色精品升级完成| 九九精品99久久久香蕉| 99久久中文字幕| 欧美午夜A∨大片久久 | 2020国产成人久久精品| 中文字幕久久久久人妻| 国产精品一区二区久久| 久久九九久精品国产免费直播| av午夜福利一片免费看久久| 久久久精品久久久久特色影视| 久久久久人妻一区二区三区vr| 99国内精品久久久久久久| 亚洲人成精品久久久久| 久久久久无码精品| 99国产欧美精品久久久蜜芽| 国产精品久久久久久久久久影院| 久久r热这里有精品视频| 77777亚洲午夜久久多喷| 精品无码人妻久久久久久| 久久精品国产99久久无毒不卡| 青青久久精品国产免费看| 久久久久综合网久久| 久久久久99精品成人片欧美| 久久亚洲精品国产精品婷婷| 国产精品久久久天天影视香蕉| 国内精品人妻无码久久久影院 | 久久国产精品国语对白| 久久亚洲AV成人出白浆无码国产| 久久夜色精品国产www| 国产高潮国产高潮久久久91 | 久久久久国色AV免费看图片| 72种姿势欧美久久久久大黄蕉| 亚洲AV无码1区2区久久| 免费精品国产日韩热久久| 久久久精品人妻无码专区不卡| 色综合久久久久网| 精品无码人妻久久久久久| 日韩久久久久中文字幕人妻| 亚洲人成无码久久电影网站| 久久毛片免费看一区二区三区|