創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買(mǎi)多久送多久,劃算不套路!
網(wǎng)站設(shè)計(jì)、做網(wǎng)站,成都做網(wǎng)站公司-成都創(chuàng)新互聯(lián)公司已向上千家企業(yè)提供了,網(wǎng)站設(shè)計(jì),網(wǎng)站制作,網(wǎng)絡(luò)營(yíng)銷(xiāo)等服務(wù)!設(shè)計(jì)與技術(shù)結(jié)合,多年網(wǎng)站推廣經(jīng)驗(yàn),合理的價(jià)格為您打造企業(yè)品質(zhì)網(wǎng)站。C++中的虛成員函數(shù)和動(dòng)態(tài)聯(lián)編是什么?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
虛成員函數(shù):
虛函數(shù)允許派生類(lèi)取代基類(lèi)所提供的實(shí)現(xiàn)。編譯器確保當(dāng)對(duì)象為派生類(lèi)時(shí),取代者(譯注:即派生類(lèi)的實(shí)現(xiàn))總是被調(diào)用,即使對(duì)象是使用基類(lèi)指針訪問(wèn)而不是派生類(lèi)的指針。這樣就允許基類(lèi)的算法被派生類(lèi)取代,即使用戶不知道派生類(lèi)的細(xì)節(jié)。
派生類(lèi)可以完全地取代基類(lèi)成員函數(shù)(覆蓋(override)),也可以部分地取代基類(lèi)成員函數(shù)(增大(augment))。如果愿意的話,后者由派生類(lèi)成員函數(shù)調(diào)用基類(lèi)成員函數(shù)來(lái)完成。
在構(gòu)造函數(shù)訪問(wèn)順序中,一般來(lái)說(shuō)是先訪問(wèn)父類(lèi)的構(gòu)造函數(shù)再訪問(wèn)子類(lèi)的構(gòu)造函數(shù),析構(gòu)函數(shù)則是先訪問(wèn)子類(lèi)的析構(gòu)函數(shù),再訪問(wèn)父類(lèi)的析構(gòu)函數(shù)。
動(dòng)態(tài)聯(lián)編:
編譯程序在編譯階段并不能確切知道將要調(diào)用的函數(shù),只有在程序運(yùn)行時(shí)才能確定將要調(diào)用的函數(shù),為此要確切知道該調(diào)用的函數(shù),要求聯(lián)編工作要在程序運(yùn)行時(shí)進(jìn)行,這種在程序運(yùn)行時(shí)進(jìn)行聯(lián)編工作被稱為動(dòng)態(tài)聯(lián)編。動(dòng)態(tài)聯(lián)編又稱動(dòng)態(tài)關(guān)聯(lián)。
編譯器對(duì)非虛方法使用靜態(tài)聯(lián)編(編譯時(shí)匹配),對(duì)虛方法使用動(dòng)態(tài)聯(lián)編(運(yùn)行時(shí)匹配)。
靜態(tài)聯(lián)編比動(dòng)態(tài)聯(lián)編效率高。
虛函數(shù)的工作原理。
虛函數(shù)。
重新定義成員函數(shù)(改變函數(shù)特征標(biāo))。
重新定義重載的成員函數(shù)。
效率
為使程序能夠在運(yùn)行階段進(jìn)行決策,必須采取一些方法來(lái)跟蹤基類(lèi)指針或引用指向的對(duì)象類(lèi)型,這增加了額外的處理開(kāi)銷(xiāo)。因此下列情況更適合靜態(tài)聯(lián)編:
因此靜態(tài)聯(lián)編被設(shè)置為C++的默認(rèn)選擇。
如果要在派生類(lèi)中重新定義基類(lèi)的方法,則將它設(shè)置為虛方法;否則設(shè)置為非虛方法。
虛函數(shù)的工作原理
編譯器處理虛函數(shù)的方法是:給每個(gè)對(duì)象添加一個(gè)隱藏成員。隱藏成員中保存了一個(gè)指向·函數(shù)地址·數(shù)組的指針。這種數(shù)組被稱為虛函數(shù)表(vtbl),表中存儲(chǔ)了為類(lèi)對(duì)象進(jìn)行聲明的虛函數(shù)的地址。
派生類(lèi)對(duì)象將包含一個(gè)指向獨(dú)立地址表的指針(即新創(chuàng)建一個(gè)表)。(增加內(nèi)存開(kāi)銷(xiāo))
調(diào)用虛函數(shù)時(shí),程序?qū)⒉榭创鎯?chǔ)在對(duì)象中的vtbl地址,然后轉(zhuǎn)向相應(yīng)的函數(shù)地址表并在表中查找地址。(影響執(zhí)行速度)
總之,使用虛函數(shù)將在內(nèi)存和執(zhí)行速度上有一定的成本;即使非函數(shù)的效率比虛函數(shù)稍高,卻不具備動(dòng)態(tài)聯(lián)編功能。
構(gòu)造函數(shù)不能是虛函數(shù)。
析構(gòu)函數(shù)應(yīng)當(dāng)是虛函數(shù),除非類(lèi)不用做基類(lèi)。
友元函數(shù)不能是虛函數(shù),因?yàn)橛言皇穷?lèi)成員,而只有成員才可以是虛函數(shù)。
如果派生類(lèi)沒(méi)有重新定義函數(shù),將使用該函數(shù)的基類(lèi)版本(繼承它)。如果派生類(lèi)位于派生鏈中,則將使用最新的虛函數(shù)版本(指針或引用調(diào)用),基類(lèi)版本被隱藏的情況除外。
重新定義將隱藏基類(lèi)方法:
class Dwelling {public: virtual void showperks(int a) const; ... };class Hovel : public Dwelling {public: virtual void showperks() const; ... }
在派生類(lèi)中重新定義函數(shù)(改變了參數(shù)特征標(biāo)),將隱藏同名的基類(lèi)方法,而不是重載基類(lèi)方法。
Hovel trump; trump.showperks(); // validtrump.showperks(5); // invalid
如果重新定義繼承的方法,應(yīng)確保與原來(lái)的原型完全相同。如果返回類(lèi)型為基類(lèi)引用或指針,則可以修改為指向派生類(lèi)的引用或指針(返回類(lèi)型協(xié)變:即允許返回類(lèi)型隨類(lèi)類(lèi)型的變化而變化)。
如果基類(lèi)聲明被重載了,則應(yīng)在派生類(lèi)中重新定義所有的基類(lèi)版本;如果只定義了一個(gè)版本,則其它版本將被隱藏,派生類(lèi)對(duì)象將無(wú)法使用它們。
class Dwelling {public: virtual void showperks(int a) const; virtual void showperks(double x) const; virtual void showperks() const; ... };class Hovel : public Dwelling { virtual void showperks(int a) const; virtual void showperks(double x) const; virtual void showperks() const; ... };
如果不需要修改,則新定義可只調(diào)用基類(lèi)版本:
void Hovel::showperks()const {Dwelling::showperks();}
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)的支持。