多態相關概念

多態相關注意事項

所謂的多態就是指函數有多中狀態, 在C++中通常是通過父類指針指向子類對象的方法實現多態, 這樣父類可以通過子類的類型調用不同的方法. 即實現一個接口多種方法, 多態的引用是爲了實現接口複用
在 C++中多態是通過虛函數來實現的. 子類通過對父類相關接口進行重寫實現一個接口多種狀態. 虛函數允許子類對父類相關接口進行重寫,

多態性的條件:

派生類的虛函數必須和基類的虛函數函數名相同, 參數相同, 返回值相同
只有類的成員函數才能實現虛函數. 靜態成員函數, 內聯函數都不能成爲虛函數
構造函數不能爲虛函數
析構函數才能定義爲虛函數
指針或者引用才能實現多態

動態聯編和靜態聯編

所謂的靜態聯編就是編譯器在編譯的時候就已經 確定了要執行那個函數, 而所謂的動態聯編就是程序在運行的時候才根據對象的類型確定執行那個函數接口

#include"iostream.h"

class A

{public:

 voidf(){cout<<"A"<<"";}

};

classB:publicA

{public:

 voidf(){cout<<"B"<<endl;}

};

Void main()

{A*pa=NULL;

Aa;Bb;

pa=&a;pa->f();

pa=&b;pa->f();

}

此時沒有構成重載, 因此在編譯的時候通過指針的類型來判斷函數調用那個接口, 此時的對象是a, 屬於A類型的一個指針, 因此執行結果便是兩個A. 要想實現當指針指向不同對象時執行不同的操作,就必須將基類中相應的成員函數定義爲虛函數,進行動態聯編

動態聯編

程序在運行的時候通過對象的類型來根據當時的情況動態的決定要執行那個接口函數. 在C++動態聯編只能通過父類指針或者父類引用調用虛函數才能實現動態聯編

#include"iostream.h"

classA

{public:

Virtual voidf()//虛函數

{cout<<"A"<<"";}};

classB:publicA

{public:

Virtual voidf()//虛函數

{cout<<"B"<<endl;}

};

voidmain()

{ A*pa=NULL;

Aa;Bb;

pa=&a;

pa->f();//A

pa=&b;

pa->f();//B

}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章