青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

chaosuper85

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

    C++虛函數探索筆記(3)——延伸思考:虛函數應用的一些其他情形

    關注問題:

    虛函數的作用

    虛函數的實現原理

    虛函數表在對象布局里的位置

    虛函數的類的sizeof

    純虛函數的作用

    多級繼承時的虛函數表內容

    虛函數如何執行父類代碼

    多繼承時的虛函數表定位,以及對象布局

    虛析構函數的作用

    虛函數在QT中的應用

    虛函數與inline修飾符,static修飾符

    虛析構函數

    大家都知道,在C++里需要自己嚴格管理好資源的分配和回收。通常情況下,

在一個對象被析構的時候,是要由其釋放其申請到的各種資源的。最常見的,當

然就是內存資源啦。

    當只有一個類的時候,我們可以不用考慮太多,只要在析構函數里檢查并釋

放所有申請到的資源即可。但是在這個類繼承了一個抽象接口基類時,就有點點

不一樣了。讓我們看看類的析構過程:

    在大多數的類的使用時,通常都是直接刪除該類的實例對象,然后該類的析

構函數就會被調用,從而使得這個類在析構函數里執行的資源釋放代碼被執行到

。

    如果這個類繼承了其他類,那么編譯器還會在這個類的析構函數里自動添加

對父類的析構函數的調用,從而將父類里申請的資源也進行釋放。如果偶多個父

類,也會依次調用各個析構函數。

    倘若繼承的是一個抽象接口類,并且在程序運行期,可能通過一個基類指針

將此對象釋放掉,那么致命而又隱藏的內存泄露BUG就出現啦……因為試圖刪除的

是基對象,刪除時調用的是基類的析構函數,而基類的析構函數當然是不會去調

用子類的析構函數的羅!

    讓我們看看下面的代碼,使用vs2008編譯并運行的時候,將會在程序運行結

束時報告內存泄漏情況(如果要在linux下編譯測試,需要去掉第一行的include

,以及return前的_CrtDumpMemoryLeaks()函數,然后使用linux下檢查內存泄

露的工具進行測試)。
 //Source filename: Win32Con.cpp
#include
class parent
{
public:
 parent() { }
 /*virtual */ ~parent() { }
};

class child:public parent
{
public:
 child()
 {
  p=new char[1000];
 }
 ~child()
 {
  delete[] p;
 }
 char *p;
};

void free_child(parent *pp)
{
 delete pp;
}

int main()
{
 child *obj=new child();
 free_child(obj);
 _CrtDumpMemoryLeaks();
 return 0;
}

 


    在這段代碼里我們創建的是一個child類型的對象,然后使用free_child

(parent*)函數來試圖釋放這個對象,這個時候,只會調用到parent::

~parent()這個析構函數,而不會調用到child::~child()!

    如何解決這個問題呢?

    很簡單的,只要在parent::~parent()前增加 virtual關鍵字,將其變成

一個虛函數。這樣,無論是以這個對象的父類指針進行刪除的時候,就會從虛函

數表里定位到子類child的析構函數,這樣就能夠從子類開始一級一級的向上調用

析構函數,從而正確的將這個對象在各個繼承層次上申請的所有資源都釋放掉。

    正因為這個原因,在很多C++編程原則的文章或者書里都會提到這樣的原則:

    如果一個類要被設計為可被繼承的基類,那么其析構函數應該被聲明為虛函

數。

   虛函數在QT中的應用

    在QT里虛函數的應用非常的廣泛,事實上,在大多數的C++類庫里都不可避免

的要使用到虛函數。這里簡單的列舉QT里使用虛函數的情況:

    QT的事件機制

    是使用了虛函數的,你因此才可以自定義事件處理函數。比如最核心的

QObject類的定義里(在qobject.h里),我們可以看到如下的虛函數定義:

    virtual bool event(QEvent *);

    virtual bool eventFilter(QObject *, QEvent *);

    然后,在QWidget類繼承QObject類后重新實現了上面的兩個虛函數,完成很

多窗口控件類的缺省事件處理。

    當你要編寫自定義的QT控件的時候,對event虛函數的重新實現就更是重要啦

    QT的信號和槽

    QT的槽函數可以被聲明為虛函數,所以雖然QT在實現信號和槽機制的時候可

能出于效率或者運行代價的原因未采用虛函數機制,但是我們依然可以在必要的

時候使用虛函數來完成一些特定功能。比如為一些自定義控件類抽象出來一個抽

象接口基類,在做信號和槽的連接的時候是對基類指針進行操作,而在基類里的

槽定義為虛函數,那么虛函數在此依然可以實現信號與槽的多態。

    然而虛函數在調用的時候,一定要經歷查表的步驟,是存在一定的運行開銷

的,對于一些非常頻繁的槽調用還是應該考慮到使用虛函數產生的代價的。

    其他

    在虛函數上,static和inline這兩個關鍵詞與virtual顯得很不友好。

    從語義上即可看出,static和virtual完全就是沖突的,所以如果你試圖為一

個虛函數增加一個static限定詞,那么你的C++編譯器就會很負責任的報告一個嚴

重錯誤給你。

    而inline的含義和虛函數其實也是非常沖突的,但是inline在語法上只是給

編譯器一個建議,而不是強制的語義限定,所以C++編譯器應該會忽略掉inline關

鍵詞,繼續正常的編譯。

 

posted on 2009-08-05 17:47 chaosuper 閱讀(310) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品一二三区| 在线视频欧美日韩| 久久综合给合| 亚洲国产va精品久久久不卡综合| 久久亚洲精品欧美| 玖玖在线精品| 亚洲精品视频二区| 亚洲精品乱码久久久久久日本蜜臀| 久久久综合免费视频| 黄色欧美日韩| 亚洲福利久久| 国产精品国产亚洲精品看不卡15| 亚洲在线成人精品| 亚洲欧美日韩国产综合| 激情久久影院| 亚洲人成网站在线播| 国产精品多人| 免费看精品久久片| 欧美精品一区二区在线播放| 亚洲一级电影| 久久久久成人精品免费播放动漫| 91久久精品国产91久久性色tv| 亚洲三级影院| 国产午夜精品麻豆| 亚洲日本免费电影| 国产在线一区二区三区四区 | 国产嫩草一区二区三区在线观看| 久久精品视频免费| 欧美国产视频在线| 久久激情五月丁香伊人| 久久综合亚洲社区| 亚洲欧美在线观看| 另类图片国产| 午夜精品在线| 欧美日韩成人一区二区| 久久国产精品99国产| 你懂的成人av| 久久精品国产亚洲a| 欧美精品一区在线发布| 久久天天狠狠| 国产精品久久久久久亚洲调教 | 亚洲欧洲一区二区在线播放| 国产精品毛片va一区二区三区| 美女尤物久久精品| 国产精品国产一区二区| 亚洲国产精品999| 国产一区二区三区在线观看免费视频 | 一区二区三区在线不卡| 一区二区三区视频观看| 亚洲区免费影片| 久久国产高清| 久久爱www久久做| 国产精品电影在线观看| 亚洲国产婷婷香蕉久久久久久| 韩国欧美一区| 欧美伊人久久| 久久爱www.| 国产精品无码永久免费888| 亚洲人成网站色ww在线| 亚洲国产乱码最新视频| 欧美在线国产| 久久婷婷人人澡人人喊人人爽| 国产精品日韩在线播放| 中文国产一区| 亚洲一区二区四区| 国产精品久久久久婷婷| 在线视频你懂得一区| 亚洲最快最全在线视频| 欧美黑人国产人伦爽爽爽| 欧美激情一区二区三区高清视频| 精品1区2区3区4区| 久久久久国产精品一区二区| 久久久噜噜噜久久中文字幕色伊伊| 国产精品无码永久免费888| 亚洲欧美激情视频| 久久久久看片| 亚洲第一在线视频| 欧美韩日视频| 中文精品一区二区三区| 午夜精品在线观看| 国产亚洲精品激情久久| 久久精品一级爱片| 欧美激情va永久在线播放| 亚洲国产精品va在线看黑人动漫| 欧美日韩综合网| 欧美激情在线| 欧美午夜精彩| 欧美天天在线| 国产精品毛片一区二区三区| 欧美精品国产一区| 国产精品久久久久久av下载红粉| 国产色爱av资源综合区| 欧美成人精品1314www| 蜜桃av综合| 日韩视频在线一区| 国产精品捆绑调教| 久久激情视频免费观看| 裸体一区二区三区| 日韩视频在线一区二区三区| 国产精品青草久久| 久久亚洲二区| 亚洲私人影院在线观看| 久久在线观看视频| 99精品国产福利在线观看免费| 国产精品狠色婷| 久久精品免费播放| 日韩午夜黄色| 蜜臀a∨国产成人精品| 一区二区欧美日韩| 尤妮丝一区二区裸体视频| 欧美精品黄色| 久久精品国产99精品国产亚洲性色 | 亚洲日本中文字幕免费在线不卡| 欧美日韩一区二区三区视频| 欧美在线观看视频| 亚洲精品免费电影| 欧美在线一二三区| 亚洲视频免费观看| 精品成人免费| 国产精品亚洲综合天堂夜夜| 免费在线观看成人av| 亚洲午夜av| 亚洲精品乱码久久久久久日本蜜臀| 久久精品一区二区三区不卡| 一本大道av伊人久久综合| 黄色欧美日韩| 国产欧美精品一区二区色综合| 欧美精品午夜视频| 久久综合伊人77777麻豆| 亚洲欧美成人一区二区在线电影 | 久久久欧美一区二区| 制服丝袜激情欧洲亚洲| 亚洲国产精品日韩| 黄色成人在线| 国内成人精品视频| 国产性色一区二区| 国产精品高精视频免费| 欧美激情黄色片| 蜜桃av一区二区在线观看| 久久福利毛片| 久久国产夜色精品鲁鲁99| 午夜视频一区在线观看| 亚洲一区在线观看免费观看电影高清| 亚洲激情成人| 亚洲精品日韩久久| 99re国产精品| 亚洲午夜一区二区三区| 一区二区日韩欧美| 国产精品99久久久久久久久久久久| 亚洲精品视频一区| 野花国产精品入口| 亚洲一区二区三区久久| 亚洲一区二区三区精品视频| 一区二区三区高清在线| 亚洲小少妇裸体bbw| 亚洲自拍偷拍一区| 性做久久久久久免费观看欧美| 亚洲欧美综合另类中字| 亚洲一区二区三区中文字幕在线| 亚洲一级一区| 久久福利一区| 欧美成人r级一区二区三区| 欧美精品一区二区久久婷婷| 欧美日韩国产免费观看| 国产精品mv在线观看| 国产精品久久精品日日| 国产午夜亚洲精品不卡| 亚洲国产精品一区二区三区| 日韩亚洲不卡在线| 午夜亚洲性色福利视频| 久久国产福利| 男女精品网站| 夜夜嗨av色综合久久久综合网 | 老司机午夜免费精品视频| 久久伊人亚洲| 亚洲欧洲另类国产综合| 亚洲欧美日韩成人高清在线一区| 亚洲欧美三级在线| 欧美成人午夜| 欧美性做爰毛片| 激情国产一区二区| 一区二区三区高清在线| 久久精品国产亚洲a| 亚洲高清在线观看| 亚洲深爱激情| 免费在线播放第一区高清av| 国产精品乱码久久久久久| 很黄很黄激情成人| 亚洲午夜久久久久久久久电影院| 午夜精品久久| 亚洲国产女人aaa毛片在线| 在线一区二区三区四区| 久久色在线观看| 国产精品视频| 亚洲精品一二区| 蜜桃av噜噜一区| 亚洲砖区区免费| 欧美日韩三级一区二区| 在线观看一区二区视频| 午夜精品久久久久久久男人的天堂|