虛函數、純虛函數

一、定義.

純虛函數是在基類中聲明的虛函數,它在基類中沒有定義,但要求任何派生類都要定義自己的實現方法。在基類中實現純虛函數的方法是在函數原型後加“=0”

virtual void funtion1()=0

二、引入原因:

1、爲了方便使用多態特性,我們常常需要在基類中定義虛擬函數。
2、在很多情況下,基類本身生成對象是不合情理的。例如,動物作爲一個基類可以派生出老虎、孔雀等子類,但動物本身生成對象明顯不合常理。

爲了解決上述問題,引入了純虛函數的概念,將函數定義爲純虛函數(方法:virtual ReturnType Function()= 0;),則編譯器要求在派生類中必須予以重載以實現多態性。同時含有純虛擬函數的類稱爲抽象類,它不能生成對象。這樣就很好地解決了上述兩個問題。

有純虛函數的類是不可能生成類對象的,如果沒有純虛函數則可以。比如:
class CA
{
public:
    virtual void fun() = 0;  // 說明fun函數爲純虛函數
    virtual void fun1();
};

class CB
{
public:
   virtual void fun();
   virtual void fun1();
};

// CA,CB類的實現
...

void main()
{
    CA a;   // 不允許,因爲類CA中有純虛函數
    CB b;   // 可以,因爲類CB中沒有純虛函數
    ...
}

三、相似概念:

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()一樣,只是在基類中不需要寫函數實現.

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