程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> C++中判斷成員函數是否重寫

C++中判斷成員函數是否重寫

編輯:關於C++

C++中判斷成員函數是否重寫。本站提示廣大學習愛好者:(C++中判斷成員函數是否重寫)文章只能為提供參考,不一定能成為您想要的結果。以下是C++中判斷成員函數是否重寫正文


C++中判斷成員函數是否重寫

判斷一個成員函數是不是虛函數(重寫),有兩個三個條件:

    兩個成員函數各自在基類和派生類中定義; 基類中定義的成員函數必須帶有關鍵字virtual,派生類的成員函數可帶可不帶。 這兩個成員函數原型(函數名,函數參數,函數返回類型)必須相同。

注意:如果這兩個函數的返回類型分別為基類和派生類,返回值為指向基類和派生類的指針或引用,則也構成重寫。此返回類型稱為協變。

調用這些成員函數時,使用對象指針,這樣當指針指向不同的對象時,就可以調用不同類的成員函數。

下面給一個程序分析:

#include<iostream>
using namespace std;

class Grandam
{
public:
  virtual void introduce_self()
  {
    cout << "I am grandam." << endl;
  }
};

class Mother:public Grandam
{
public:
  void introdude_self()
  {
    cout << "I am mother." << endl;
  }
};

class Daughter :public Mother
{
public:
  void introduce_self()
  {
    cout << "I am daughter." << endl;
  }
};

int main()
{
  Grandam* ptr;
  Grandam g;
  Mother m;
  Daughter d;
  ptr = &g;
  ptr->introduce_self();

  ptr = &m;
  ptr->introduce_self();

  ptr = &d;
  ptr->introduce_self();
  return 0;
}

結果如圖所示:

從結果可知,每次都執行了成員函數的虛函數introduce_self()版本,解決了繼承來的二義性問題。

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved