C++中virtual(虛函數)的用法
阿新 • • 發佈:2017-09-18
this char 基類 變化 代碼 程序 但是 cnblogs else
轉載:http://blog.csdn.net/foreverhuylee/article/details/34107615
在面向對象的C++語言中,虛函數(virtual function)是一個非常重要的概念。
什麽是虛函數:
虛函數是指一個類中你希望重載的成員函數 ,當你用一個 基類指針或引用 指向一個繼承類對象的時候,調用一個虛函數時, 實際調用的是繼承類的版本。 ——摘自MSDN
舉例:
1 #include "stdio.h" 2 #include "conio.h" 3 4 class Parent 5 6 { 7 8 public: 9 10 char data[20]; 11 void Function1(); 12 virtual void Function2(); // 這裏聲明Function2是虛函數 13 14 }parent; 15 16 void Parent::Function1() 17 { 18 printf("This is parent,function1\n"); 19 } 20 21 void Parent::Function2() 22 23 { 24 printf("This is parent,function2\n"); 25 } 26 27 class Child:public Parent 28 29 { 30 void Function1(); 31 void Function2(); 32 33 } child; 34 35 void Child::Function1() 36 37 { 38 printf("This is child,function1\n"); 39 } 4041 void Child::Function2() 42 43 { 44 printf("This is child,function2\n"); 45 } 46 47 int main(int argc, char* argv[]) 48 49 { 50 Parent *p; // 定義一個基類指針 51 if(_getch()==‘c‘) // 如果輸入一個小寫字母c 52 p=&child; // 指向繼承類對象 53 else 54 p=&parent; // 否則指向基類對象 55 p->Function1(); // 這裏在編譯時會直接給出Parent::Function1()的入口地址。 56 p->Function2(); // 註意這裏,執行的是哪一個Function2? 57 return 0; 58 59 }
用任意版本的Visual C++或Borland C++編譯並運行,輸入一個小寫字母c,得到下面的結果:
1 This is parent,function1 2 This is child,function2
為什麽會有第一行的結果呢?
因為我們是用一個Parent類的指針調用函數Fuction1(),雖然實際上這個指針指向的是Child類的對象,但編譯器無法知道這一事實(直到運行的時候,程序才可以根據用戶的輸入判斷出指針指向的對象),它只能按照調用Parent類的函數來理解並編譯,所以我們看到了第一行的結果。 那麽第二行的結果又是怎麽回事呢?我們註意到,Function2()函數在基類中被virtual關鍵字修飾,也就是說,它是一個虛函數。
虛函數最關鍵的特點是“動態聯編”,它可以在運行時判斷指針指向的對象,並自動調用相應的函數。
如果我們在運行上面的程序時任意輸入一個非c的字符,結果如下:
1 This is parent,function1 2 This is parent,function2
請註意看第二行,它的結果出現了變化。程序中僅僅調用了一個Function2()函數,卻可以根據用戶的輸入自動決定到底調用基類中的Function2還是繼承類中的Function2,這就是虛函數的作用。
PS:一定要註意“靜態聯翩 ”和“ 動態聯編 ”的區別;對於我來說,若沒有在VC6.0中親自去測試,憑自己的感覺,
當在鍵盤中輸入“c”時,我會覺得由於有p=&child;這一句代碼,我會認為結果都是:
1 This is child,function1 2 This is child,function2
但是結果卻是:
1 This is parent,function1 2 This is child,function2
因為雖然實際上這個指針指向的是Child類的對象,但編譯器無法知道這一事實,它只能按照調用Parent類的函數來理解並編譯,所以我們看到了第一行的結果。
第二行中調用了子類的function2,完全是因為virtual 的功能,virtual實現了動態聯編,它可以在運行時判斷指針指向的對象,並自動調用相應的函數。
1 p=&parent; //這一句,該指針很明顯的是指向父類,那麽肯定調用的是父類的方法
C++中virtual(虛函數)的用法