溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解決C++多重繼承引發(fā)的重復調(diào)用的問題

發(fā)布時間:2021-07-16 14:52:09 來源:億速云 閱讀:145 作者:小新 欄目:編程語言

這篇文章主要介紹如何解決C++多重繼承引發(fā)的重復調(diào)用的問題,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

分析一個多重繼承引發(fā)的重復調(diào)用問題,先來看看問題代碼:

#include "stdafx.h"
#include<stdlib.h>
#include<iostream>
using namespace std;
class R//祖先類
{
private:
  int r;
public:
  R(int x = 0):r(x){}
  void f()
  {
    cout << " r = " << r << endl;
  }
  void print()
  {
    cout << "print R = " << r << endl;
  }
};
//虛繼承
class A : virtual public R
{
private:
  int a;
public:
  A(int x,int y):R(x),a(y){}
  //重寫父類的f()函數(shù)
  void f()
  {
    cout << "a = " << a << endl;
    R::f();//r是私有成員變量,不能直接訪問,通過作用域進行訪問被派生類覆蓋的函數(shù)f()
  }
};
//虛繼承
class B : virtual public R
{
private:
  int b;
public:
  B(int x, int y) :R(x), b(y) {}
  //重寫父類的f()函數(shù)
  void f()
  {
    cout << "b = " << b << endl;
    R::f();//r是私有成員變量,不能直接訪問,通過作用域進行訪問被派生類覆蓋的函數(shù)f()
  }
};
class C :public A, public B
{
private:
  int c;
public:
  C(int x,int y,int z,int m):R(x),A(x,y),B(x,z),c(m)
  { }
  void f()
  {
    cout << "c = " << c << endl;
    A::f();//此時A里面有一個 r 的輸出,和輸出a
    B::f();//B里面也有一個r的輸出,和輸出b
    //從而導致重復調(diào)用,兩次輸出 r
  }
};
int main()
{
  C cc(1212, 345, 123, 45);
  cc.f();
  system("pause");
  return 0;
}

解決辦法:針對重復調(diào)用,每個類把屬于自己的工作單獨封裝

修改后的代碼如下:

#include "stdafx.h"
#include<stdlib.h>
#include<iostream>
using namespace std;
class R//祖先類
{
private:
  int r;
public:
  R(int x = 0):r(x){}
  void f()
  { cout << " r = " << r << endl;    }
  virtual void print()
  { cout << "print R = " << r << endl;}
};
//虛繼承
class A : virtual public R//virtual寫在public的前后均可以
{
private:
  int a;
public:
  A(int x,int y):R(x),a(y){ }
protected:
  void fA()//增加一個保護函數(shù),只打印自己的擴展成員
  {
    cout << "a = " << a << endl;
  }
  void f()//重寫父類的f()函數(shù)
  {
    //cout << "a = " << a << endl;
    fA();
    R::f();//r是私有成員變量,不能直接訪問,通過作用域進行訪問被派生類覆蓋的函數(shù)f()
  }
};
//虛繼承
class B : virtual public R
{
private:
  int b;
public:
  B(int x, int y) :R(x), b(y) {}
protected:
  void fB()//增加一個保護函數(shù),只打印自己的擴展成員
  {
    cout << "b = " << b << endl;
  }
  void f()//重寫父類的f()函數(shù)
  {
    fB();
    R::f();//r是私有成員變量,不能直接訪問,通過作用域進行訪問被派生類覆蓋的函數(shù)f()
  }
};
class C :public A, public B
{
private:
  int c;
public:
  C(int x,int y,int z,int m):R(x),A(x,y),B(x,z),c(m)
  { }
  void f()
  {
    cout << "c = " << c << endl;
    R::f();
    //A::f();//此時A里面有一個 r 的輸出,和輸出a
    //B::f();//B里面也有一個r的輸出,和輸出b
    //從而導致重復調(diào)用,兩次輸出 r
    fA();//A::fA();
    fB();//A::fB();
  }
};
int main()
{
  C cc(1212, 345, 123, 45);
  cc.f();
  system("pause");
  return 0;
}

以上是“如何解決C++多重繼承引發(fā)的重復調(diào)用的問題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

c++
AI