面向对象的多态性(2)
1、虛函數
在c++中,可以調用虛函數來實現運行時的多態性,,這樣可以進行函數的重載
虛函數的定義是在基類中進行的,,當吧基類中的某一個成員函數定義成虛函數之后,就可以在派生類中重新定義,
在派生類重新定義的時候,函數的原型包含函數參數,函數名,參數的個數和類型,以及參數的順序都必須和基類中的函數一樣
虛函數的定義形式:
virtual <函數類型》《函數名》(參數表)
{
? ? 函數體
}
該函數定義一個虛函數,在派生類總繼承基類,對虛函數重新的定義
<span style="font-size:18px;">#include<iostream> using namespace std; class animal { public:void sleep(){cout << "animal is sleeping" << endl;}virtual void breath(){cout << "aniaml is breathing" << endl;} }; class fish :public animal { public:void breath(){cout << "fish is breathing" << endl;} };int main() {animal an;an.breath();fish fh;fh.breath();animal *ann = &fh;ann->breath();system("pause");return 0;}</span>在基類函數中間virtual關鍵字 后,當基類對象的指針指向fish類的對象時,會調用fish類中的函數,得到預期的效果
當基類的成員函數breath()函數定義為虛函數時,編譯器為每個包含虛函數的類創建一個虛表
類aniaml的虛表: &animal::breath()---------------------->animal::breath()
類fish的虛表:&fish::reath()-------------------------------->fish::brath()
當使用fish類的fh對象狗仔完后,,其內部的虛表指針按初始化指向fish類的虛表,
當進行類型轉換后,調用ann-》breath()函數,由于ann實際指向的是fish對象,該對象內部的虛表指針指向的是fishle類的
虛表,最終調用fish類的breath()函數
在調用虛函數注意:
1、虛函數只能定義在基類中
2、重載的函數,要求函數名、返回類型、參數個數、參數類型和參數順序必須和基類中的函數一樣
3、在用基類對象訪問重載函數時,需用指針進行調用
2、多級繼承和虛函數
多級繼承可以看作多個繼承的組合,多級繼承的虛函數和單繼承的而虛函數相同,一個虛函數無論被繼承多少次,仍然保持虛函數的特性,與繼承次數無關
例子:
#include<iostream> using namespace std; class base { public:virtual ~base(){};virtual void func(){cout << "base output" << endl;} }; class derive1 :public base { public:void func(){cout << "derive1 output" << endl;} }; class derive2 :public derive1 {void func(){cout << "derive2 output" << endl;} };void test(base &b) {b.func(); } int main() {base bob;derive1 dob1;derive2 dob2;test(bob);test(dob1);test(dob2);system("pause");return 0; }
總結
以上是生活随笔為你收集整理的面向对象的多态性(2)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: RANSC算法(随机样本一致性)
- 下一篇: 面向对象的多态性(3)