C++中关于隐藏的理解
引言
在使用中弄清楚隱藏的區別之后,還需要明白怎么使用。下面說以下隱藏,重寫,重載的區別:
與重載的區別:
在父類與子類中,函數名相同,參數不同,無論父類中的同名函數是否含有virtual關鍵字,都是隱藏;
與重寫的區別:
在父類和子類中,函數名相同,參數相同,父類中的同名函數沒有virtual關鍵字,為隱藏。
示例
下面舉例說明:
class Base {public:void funA(){cout<<"funA()"<<endl;}virtual void funB(){cout<<"funB()"<<endl;} };class Heri:public Base {public:void funA(){cout<<"funA():Heri"<<endl;}void funA(int a){cout<<"funA(int a):heri"<<a<<endl;}void funB(){cout<<"funB():heri"<<endl;} };以上示例中,基類中的函數funA()與派生類中的函數funA()之間是隱藏,其函數名相同,參數相同,存在于派生類于子類中,且基類中的funA()函數前沒有virtual關鍵字,故為隱藏。基類的函數funA()與派生類中的函數funA(int a)函數名相同,參數不同,存在于基類和派生類中,無論基類有沒有關鍵字virtual兩個函數之間也是隱藏,基類函數funB()與派生類函數funB()之間是重寫,又叫覆蓋,當重寫發生的情況下,父類的指針或引用指向子類的對象,通過父類的指針或引用調用父子類中被重寫的函數,實際上調用的是子類的函數,這個具體得理解虛函數,多態這塊,這里不再提及。以上是對函數之間關系的一種分析,接下來應該看看如何使用隱藏,隱藏使用的時候記住一句,派生類的指針或引用,對象調用子類和父類同名的函數,父類的同名函數被子類隱藏,調用的是子類的函數,當然這句話是針對于隱藏關系的函數的而言。接下來看如何應用。
隱藏的應用
下面是一個小程序,上代碼:
// hideDemo.cpp : 定義控制臺應用程序的入口點。 //#include "stdafx.h" #include <iostream> #include <stdlib.h>using namespace std;class Base { public:void fun1(){cout<<"base:fun1()"<<endl;fun();}virtual void fun(){cout<<"base:fun()"<<endl;} };class Deriverd:public Base { public:virtual void fun1(){cout<<"deriverd:fun1()"<<endl;}void fun(){cout<<"deriverd:fun()"<<endl;} };int _tmain(int argc, _TCHAR* argv[]) {Base *pb = new Deriverd;pb->fun1();system("pause");return 0; }上面是一個小程序,輸出結果為:
之所以輸出是上面的結果是因為main函數中創建了父類的指針指向了子類的對象,然后通過父類的指針調用具有隱藏關系的fun1()函數,該函數在使用時記住一句“派生類的指針,引用,對象調用父類或者派生類中的同名函數,調用的是子類的函數”,這句話一聽就會被誤解,pb->fun1();以為調用的是子類的函數fun1(),實際并不是,上句話有一個前提,是派生類的對象或引用,指針進行調用,而這里是父類的指針調用,這樣的解釋過于牽強,我總結出的經驗就是,隱藏關系的函數,誰調用就用誰的函數,按照正常的函數調用使用便可得正確的結果,這里是父類指針調用,就用父類的函數fun1().當然這只適用于作答,真正的理解還得從書上給出的解釋入手。
鞏固
下面基于上面的理解,看看下面的程序:
// hideDemo.cpp : 定義控制臺應用程序的入口點。 //#include "stdafx.h" #include <iostream> #include <stdlib.h>using namespace std;class Base { public:void fun1(){cout<<"base:fun1()"<<endl;fun();}virtual void fun(){cout<<"base:fun()"<<endl;} };class Deriverd:public Base { public:virtual void fun1(){cout<<"deriverd:fun1()"<<endl;}void fun(){cout<<"deriverd:fun()"<<endl;} };int _tmain(int argc, _TCHAR* argv[]) {Base *pb = new Deriverd;pb->fun1();Deriverd de;de.fun1();Base b;b.fun1();system("pause");return 0; }輸出結果:
定義派生類對象Deriverd de;通過派生類對象調用fun1(),這里調用的是派生類自己的函數fun1(),應了那句“派生類的對象,指針,引用調用派生類和基類的同名函數,調用的是派生類的函數,父類的函數被隱藏”,定義基類對象 Base b;通過對象b調用函數fun1(), 調用的是基類的函數fun1().然后在fun1()中輸出base:fun1(),接著調用函數fun(),這里的函數fun()調用的是基類自身的函數fun(),因為沒有此時沒有涉及到多態,這里是父類的對象調用的,不是父類的指針,或者引用調用。
總結
以上是生活随笔為你收集整理的C++中关于隐藏的理解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mac上用qt调用自己生成的qt动态库,
- 下一篇: C/C++ _wcslwr_s 函数 –