Posted on 2011-09-25 10:11
Shuffy 閱讀(1380)
評論(0) 編輯 收藏 引用 所屬分類:
VC++/C/C++/C#瀏覽集合
虛函數:虛函數是C++中用于實現多態(polymorphism)的機制。核心理念就是通過基類訪問派生類定義的函數。是C++中多態性的一個重要體現,利用基類指針訪問派生類中的成員 函數,這種情況下使用虛函數,這種情況下采用的是動態綁定技術。
虛函數必須是基類的非靜態成員函數,其訪問權限可以是protected或public,在基類的類定義中定義虛函數的一般形式:
virtual 函數返回值類型 虛函數名(形參表)
{ 函數體 }
動態綁定:基類指針是調用派生類的中的成員函數還是調用基類中的成員函數要到程序運行時確定。主要要看指針所指向的對象。
純虛函數:純虛函數是在基類中聲明的虛函數,它在基類中沒有定義,但要求任何派生類都要定義自己的實現方法。在基類中實現純虛函數的方法是在函數原型后加“=0”
virtual void funtion1()=0
虛基類、抽象類:包含純虛函數的類稱為抽象類。由于抽象類包含了沒有定義的純虛函數,所以不能定義抽象類的對象。
虛函數繼承:
虛函數繼承就是覆蓋。即基類中的虛函數被派生類中的同名函數所覆蓋。 是實現多態的方法。
class parent
{
public:
vitual void foo(){cout < <"foo from parent";};
void foo1(){cout < <"foo1 from parent";};
};
class son:public parent
{
void foo(){cout < <"foo from son";};
void foo1(){cout < <"foo1 from son";};
};
int main()
{
parent *p=new son();
p->foo();
p->foo1();
return 0;
}
其輸出結果是:
foo from son,foo1 from parent
虛繼承:
解決多重繼承中派生類成員函數調用模糊問題。比如類A中有一個函數print(),類B繼承A,類C繼承A,類D繼承類B和類C,這個時候,類D中就有兩個print函數,一個是 從B繼承得到的,一個是從C繼承得到的,則,類D的對象調用print函數就會出現print模糊的編譯錯誤。解決辦法:類B虛擬繼承A。類C虛擬繼承A,類D繼承B,C時,只拷 貝A中的數據成員和函數成員一次,再遇到拷貝時候就忽略了!
虛繼承就是為了節約內存的,他是多重繼承中的特有的概念。適用與菱形繼承形式。
如:類B、C都繼承類A,D繼承類B和C。為了節省內存空間,可以將B、C對A的繼承定義為虛擬繼承,此時A就成了虛擬基類。
class A;
class B:public vitual A;
class C:public vitual A;
class D:public B,public C;
原文地址:http://www.cnblogs.com/elwinch/articles/2038088.html