今天小編給大家分享一下C++中基類對(duì)象怎么轉(zhuǎn)換為派生類對(duì)象的相關(guān)知識(shí)點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識(shí),所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來(lái)了解一下吧。
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了新?lián)崦赓M(fèi)建站歡迎大家使用!
通常,為了實(shí)現(xiàn)多態(tài)性,我們將基類的指針或引用指向派生類對(duì)象。而當(dāng)需要使用該派生類對(duì)象的特有方法時(shí),可以通過(guò)將基類指針轉(zhuǎn)換為派生類指針以達(dá)到目的。這樣做總是合法的。也許在某些特殊情況下,需求剛好相反,我們需要將基類對(duì)象轉(zhuǎn)換為派生類對(duì)象。沒(méi)錯(cuò),是對(duì)象對(duì)象,不是指針。先看一下我們的基類和子類的示例代碼吧!
// // CBase.h // #ifndef __C_BASE_H #define __C_BASE_H using std::string; using std::cout; using std::endl; class CBase { protected : string _name; public : CBase(const string &name); virtual ~CBase(void); }; inline CBase::CBase(const string &name) : _name(name) {NULL; } inline CBase::~CBase(void) { NULL; } #endif // __C_BASE_H
好的,下面讓我們來(lái)看一下如何轉(zhuǎn)換:
// main.c #include#include "CBase.h" #include "CDerived.h" int main(void) { CBase base("father"); CDerived derived("son"); // 錯(cuò)誤的調(diào)用, 基類 CBase 沒(méi)有方法 whoAmI // base.whoAmI(); // 調(diào)用派生類 CDerived 特有的方法 whoAmI derived.whoAmI(); // 錯(cuò)誤的轉(zhuǎn)換 // dynamic_cast (base)->whoAmI(); // 基類轉(zhuǎn)換為派生類, 通過(guò)編譯,正常運(yùn)行. static_cast (base).whoAmI(); return 0; }
復(fù)制代碼從上面的代碼可以看到,方法 whoAmI 是派生類 CDerived 所特有的,基類對(duì)象無(wú)法調(diào)用它。而意圖使用 dynamic_cast 動(dòng)態(tài)地將基類對(duì)象 base 轉(zhuǎn)換為派生類對(duì)象,會(huì)導(dǎo)致編譯器報(bào)錯(cuò),因?yàn)檫\(yùn)行時(shí),基類對(duì)象 base 在內(nèi)存中不可能包含派生類的屬性和方法。
為什么使用 static_cast 靜態(tài)地轉(zhuǎn)換卻可以呢?這條轉(zhuǎn)換語(yǔ)句并不是在任何情況下都可以通過(guò)編譯。事實(shí)上,運(yùn)行時(shí)并沒(méi)有發(fā)生過(guò)轉(zhuǎn)換過(guò)程,我們只是做了一個(gè)小動(dòng)作——以基類對(duì)象 base 為參照,另外構(gòu)造了一個(gè)臨時(shí)派生類對(duì)象。先回顧一下運(yùn)行結(jié)果:
I am son ! CDerived::CDerived(const CBase &base); I am father !
然后再回頭看一下派生類 CDerived 的代碼,運(yùn)行時(shí)下面的復(fù)制構(gòu)造函數(shù)被執(zhí)行了:
CDerived(const CBase &base);
復(fù)制代碼但與默認(rèn)復(fù)制構(gòu)造函數(shù)不同,它的參數(shù)為其基類對(duì)象的引用,這樣我們構(gòu)造出來(lái)的派生類對(duì)象在內(nèi)存中,其基類部分就與 base 完全一樣了。
inline CDerived::CDerived(const string &name): CBase(name) { NULL; }
復(fù)制代碼因此,我們可以得出一個(gè)結(jié)論,在使用 static_cast 進(jìn)行轉(zhuǎn)換時(shí),編譯器隱式地為我們調(diào)用了復(fù)制構(gòu)造函數(shù)。但是有一點(diǎn)需要注意,由于調(diào)用的復(fù)制構(gòu)造函數(shù)參數(shù)類型與自身類型不同, 故我們必須親自編寫這個(gè)復(fù)制構(gòu)造函數(shù),如果沒(méi)有,編譯器將因?yàn)檎也坏胶线m的構(gòu)造函數(shù)而報(bào)錯(cuò)。
以上就是“C++中基類對(duì)象怎么轉(zhuǎn)換為派生類對(duì)象”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會(huì)為大家更新不同的知識(shí),如果還想學(xué)習(xí)更多的知識(shí),請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。