C++純虛函式
定義
純虛函式是在基類中聲明的虛函式,它可以在基類中有定義,而且派生類必須定義自己的實現方法。基類不能生成對象,可以使用指針或者引用派生類對象。基類不在基類中實現純虛函式的方法是在函式原型後加“=0”
virtual void funtion1()=0
引入原因
1、為了方便使用多態特性,我們常常需要在基類中定義虛擬函式。
2、在很多情況下,基類本身生成對象是不合情理的。例如,動物作為一個基類可以派生出老虎、孔雀等子類,但動物本身生成對象明顯不合常理。
為了解決上述問題,引入了純虛函式的概念,將函式定義為純虛函式(方法:virtual ReturnType Function()= 0;),則編譯器要求在派生類中必須予以重寫以實現多態性。同時含有純虛擬函式的類稱為抽象類,它不能生成對象。這樣就很好地解決了上述兩個問題。
相似概念
1、多態性
指相同對象收到不同訊息或不同對象收到相同訊息時產生不同的實現動作。C++支持兩種多態性:編譯時多態性,運行時多態性。
a.編譯時多態性:通過重載函式實現
b 運行時多態性:通過虛函式實現。
2、虛函式
虛函式是在基類中被聲明為virtual,並在派生類中重新定義的成員函式,可實現成員函式的動態重載
3、抽象類
包含純虛函式的類稱為抽象類。由於抽象類包含了沒有定義的純虛函式,所以不能定義抽象類的對象。
程式舉例
基類:
class A
{
public:
A();
void f1();
virtual void f2();
virtual void f3()=0;
virtual ~A();
};
子類:
class B : public A
{
public:
B();
void f1();
void f2();
void f3();
virtual ~B();
};
主函式:
int main(int argc, char* argv[])
{
A *m_j=new B();
m_j->f1();
m_j->f2();
m_j->f3();
delete m_j;
return 0;
}
f1()是一個普通的重載.
調用m_j->f1();會去調用A類中的f1(),它是在我們寫好代碼的時候就會定好的.
也就是根據它是由A類定義的,這樣就調用這個類的函式.
f2()是虛函式.
調用m_j->f2();會調用m_j中到底保存的對象中,對應的這個函式.這是由於new的B對象.
f3()與f2()一樣,只是在基類中不需要寫函式實現.