C++ 基類(lèi)指針和子類(lèi)指針相互賦值的實(shí)現(xiàn)方法
首先,給出基類(lèi)animal和子類(lèi)fish
//============================================================== // animal.h // // author : zwq // describe: 非虛函數(shù)情況下,將子類(lèi)指針賦給積累指針,驗(yàn)證最終調(diào)用 // 基類(lèi)函數(shù)還是子類(lèi)函數(shù)。 //============================================================== #ifndef ANIMAL_H #define ANIMAL_H //=============================================================== // // animal // 動(dòng)物基類(lèi) // //=============================================================== class animal { public: void breathe(); // 非虛函數(shù) }; //=============================================================== // // animal // 魚(yú)類(lèi),集成于動(dòng)物基類(lèi) // //=============================================================== class fish : public animal { public: void breathe(); // 非虛函數(shù) }; #endif
#include "StdAfx.h" #include <iostream> #include "Animal.h" using namespace std; //=============================================================== // // animal // 動(dòng)物基類(lèi) // //=============================================================== void animal::breathe() { cout << "animal breathe" << endl; } //=============================================================== // // animal // 魚(yú)類(lèi),集成于動(dòng)物基類(lèi) // //=============================================================== void fish::breathe() { cout << "fish bubble" << endl; }
一. 基類(lèi)指針和子類(lèi)指針之間相互賦值
(1)將子類(lèi)指針賦值給基類(lèi)指針時(shí),不需要進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)換,C++編譯器將自動(dòng)進(jìn)行類(lèi)型轉(zhuǎn)換。因?yàn)樽宇?lèi)對(duì)象也是一個(gè)基類(lèi)對(duì)象。
(2)將基類(lèi)指針賦值給子類(lèi)指針時(shí),需要進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)換,C++編譯器將不自動(dòng)進(jìn)行類(lèi)型轉(zhuǎn)換。因?yàn)榛?lèi)對(duì)象不是一個(gè)子類(lèi)對(duì)象。子類(lèi)對(duì)象的自增部分是基類(lèi)不具有的。
執(zhí)行以下代碼,看看會(huì)報(bào)什么錯(cuò)誤:
int main(int argc, char* argv[]) { ExamAnimal(); return 0; } void ExamAnimal() { // 將子類(lèi)指針直接賦給基類(lèi)指針,不需要強(qiáng)制轉(zhuǎn)換,C++編譯器自動(dòng)進(jìn)行類(lèi)型轉(zhuǎn)換 // 因?yàn)閒ish對(duì)象也是一個(gè)animal對(duì)象 animal* pAn; fish* pfh = new fish; pAn = pfh; delete pfh; pfh = NULL; // 將基類(lèi)指針直接賦給子類(lèi)指針,需要強(qiáng)制轉(zhuǎn)換,C++編譯器不會(huì)自動(dòng)進(jìn)行類(lèi)型轉(zhuǎn)換 // 因?yàn)閍nimal對(duì)象不是一個(gè)fish對(duì)象 fish* fh1; animal* an1 = new animal; // 沒(méi)有進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)化 fh1 = an1; delete an1; an1 = NULL; }
編譯時(shí),報(bào)如下錯(cuò)誤信息:
--------------------Configuration: CPlusPlusPrimer - Win32 Debug-------------------- Compiling... CPlusPlusPrimer.cpp E:\Study\example\CPlusPlusPrimer\CPlusPlusPrimer.cpp(94) : error C2440: '=' : cannot convert from 'class animal *' to 'class fish *' Types pointed to are unrelated; conversion requires reinterpret_cast, C-style cast or function-style cast Error executing cl.exe.
CPlusPlusPrimer.exe - 1 error(s), 0 warning(s)
根據(jù)以上錯(cuò)題提示信息,對(duì)代碼做如下修改:
void ExamAnimal() { // 將子類(lèi)指針直接賦給基類(lèi)指針,不需要強(qiáng)制轉(zhuǎn)換,C++編譯器自動(dòng)進(jìn)行類(lèi)型轉(zhuǎn)換 // 因?yàn)閒ish對(duì)象也是一個(gè)animal對(duì)象 animal* pAn; fish* pfh = new fish; pAn = pfh; delete pfh; pfh = NULL; // 將基類(lèi)指針直接賦給子類(lèi)指針,需要強(qiáng)制轉(zhuǎn)換,C++編譯器不會(huì)自動(dòng)進(jìn)行類(lèi)型轉(zhuǎn)換 // 因?yàn)閍nimal對(duì)象不是一個(gè)fish對(duì)象 fish* fh1; animal* an1 = new animal; // 修改處: // 進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)化 fh1 = (fish*)an1; delete an1; an1 = NULL; }
再次編譯,通過(guò)。
二. 子類(lèi)指針賦給基類(lèi)指針時(shí)內(nèi)存分析
(1)int變量賦給char變量
整型int轉(zhuǎn)換為char類(lèi)型時(shí),只有一個(gè)字節(jié)的內(nèi)容能夠放進(jìn)char類(lèi)型,剩下的三個(gè)字節(jié)內(nèi)容放不下,被截掉,丟失精度。 兩個(gè)變量或者對(duì)象進(jìn)行轉(zhuǎn)換時(shí),一定要看兩者的內(nèi)存模型是否互相匹配。
(2)子類(lèi)fish指針賦給基類(lèi)animal指針
下面看看子類(lèi)fish指針賦給基類(lèi)animal指針時(shí),內(nèi)存的變化: 當(dāng)我們構(gòu)造fish類(lèi)的對(duì)象時(shí),首先要調(diào)用animal類(lèi)的構(gòu)造函數(shù)去構(gòu)造animal類(lèi)的構(gòu)造函數(shù),然后才調(diào)用fish類(lèi)的構(gòu)造函數(shù)完成自身部分的構(gòu)造,從而拼接出一個(gè)完整的fish對(duì)象。當(dāng)我們將fish類(lèi)對(duì)象轉(zhuǎn)換為animal類(lèi)對(duì)象時(shí),該對(duì)象就被認(rèn)為是原對(duì)象整個(gè)內(nèi)存模型的上半部分,也就是圖中animal對(duì)象的內(nèi)存部分。當(dāng)我們利用類(lèi)型轉(zhuǎn)換后的對(duì)象指針去調(diào)用它的方法時(shí),自然是調(diào)用它所在的內(nèi)存中的方法。 在這里,animal類(lèi)對(duì)象類(lèi)似于char類(lèi)型的對(duì)象,fish類(lèi)對(duì)象類(lèi)似于int類(lèi)型的對(duì)象,將fish類(lèi)對(duì)象賦給animal類(lèi)對(duì)象時(shí),會(huì)截取fish類(lèi)對(duì)象自身的部分,剩下fish類(lèi)對(duì)象中的animal部分。
(3)基類(lèi)animal指針賦給子類(lèi)fish指針
基類(lèi)animal對(duì)象包含的信息少,類(lèi)fish對(duì)象包含的信息多,將信息少的對(duì)象直接轉(zhuǎn)換為信息多的對(duì)象時(shí)(沒(méi)有強(qiáng)制類(lèi)型轉(zhuǎn)換),顯然是無(wú)法構(gòu)造出多出的信息。在編譯時(shí),也會(huì)發(fā)生如下錯(cuò)誤:error C2440: '=' : cannot convert from 'class animal *' to 'class fish *'。 這時(shí),需要做強(qiáng)制類(lèi)型轉(zhuǎn)換:
// 將基類(lèi)指針直接賦給子類(lèi)指針,需要強(qiáng)制轉(zhuǎn)換,C++編譯器不會(huì)自動(dòng)進(jìn)行類(lèi)型轉(zhuǎn)換 // 因?yàn)閍nimal對(duì)象不是一個(gè)fish對(duì)象 fish* fh1; animal* an1 = new animal; // 進(jìn)行強(qiáng)制類(lèi)型轉(zhuǎn)化 fh1 = (fish*)an1;
以上就是小編為大家?guī)?lái)的C++ 基類(lèi)指針和子類(lèi)指針相互賦值的實(shí)現(xiàn)方法全部?jī)?nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-用棧實(shí)現(xiàn)表達(dá)式求值的方法詳解
本篇文章是對(duì)在c語(yǔ)言中用棧實(shí)現(xiàn)表達(dá)式求值的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C語(yǔ)言實(shí)現(xiàn)經(jīng)典24點(diǎn)紙牌益智游戲
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)經(jīng)典24點(diǎn)紙牌益智游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10C++如何動(dòng)態(tài)的生成對(duì)象詳解
C++是不支持根據(jù)類(lèi)名動(dòng)態(tài)地生成對(duì)象的,比如從一個(gè)文本文件中讀取類(lèi)名然后構(gòu)造一個(gè)對(duì)象.主要原因是沒(méi)有豐富的動(dòng)態(tài)元信息,沒(méi)有單根類(lèi)庫(kù)。那么下面這篇文章就來(lái)給大家介紹C++是如何動(dòng)態(tài)的生成對(duì)象,有需要的朋友們可以參考借鑒。2017-02-02C++11/14如何使用typedef和using定義類(lèi)型別名和別名模版
這篇文章主要介紹了C++11/14如何使用typedef和using定義類(lèi)型別名和別名模版2023-04-04DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--浮點(diǎn)數(shù)的存儲(chǔ)格式
本文主要介紹DSP中浮點(diǎn)數(shù)的存儲(chǔ)格式,很值得學(xué)習(xí)一下,需要的朋友可以參考一下。2016-06-06