中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

如何解決C++多重繼承引發的重復調用的問題

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

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

分析一個多重繼承引發的重復調用問題,先來看看問題代碼:

#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()函數
  void f()
  {
    cout << "a = " << a << endl;
    R::f();//r是私有成員變量,不能直接訪問,通過作用域進行訪問被派生類覆蓋的函數f()
  }
};
//虛繼承
class B : virtual public R
{
private:
  int b;
public:
  B(int x, int y) :R(x), b(y) {}
  //重寫父類的f()函數
  void f()
  {
    cout << "b = " << b << endl;
    R::f();//r是私有成員變量,不能直接訪問,通過作用域進行訪問被派生類覆蓋的函數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
    //從而導致重復調用,兩次輸出 r
  }
};
int main()
{
  C cc(1212, 345, 123, 45);
  cc.f();
  system("pause");
  return 0;
}

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

修改后的代碼如下:

#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()//增加一個保護函數,只打印自己的擴展成員
  {
    cout << "a = " << a << endl;
  }
  void f()//重寫父類的f()函數
  {
    //cout << "a = " << a << endl;
    fA();
    R::f();//r是私有成員變量,不能直接訪問,通過作用域進行訪問被派生類覆蓋的函數f()
  }
};
//虛繼承
class B : virtual public R
{
private:
  int b;
public:
  B(int x, int y) :R(x), b(y) {}
protected:
  void fB()//增加一個保護函數,只打印自己的擴展成員
  {
    cout << "b = " << b << endl;
  }
  void f()//重寫父類的f()函數
  {
    fB();
    R::f();//r是私有成員變量,不能直接訪問,通過作用域進行訪問被派生類覆蓋的函數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
    //從而導致重復調用,兩次輸出 r
    fA();//A::fA();
    fB();//A::fB();
  }
};
int main()
{
  C cc(1212, 345, 123, 45);
  cc.f();
  system("pause");
  return 0;
}

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

向AI問一下細節

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

c++
AI

浦北县| 本溪市| 邵东县| 昔阳县| 长垣县| 中超| 象山县| 乌恰县| 鱼台县| 铜陵市| 页游| 米易县| 西贡区| 万安县| 金沙县| 阿瓦提县| 揭西县| 富源县| 镇坪县| 嘉义市| 涞源县| 沁源县| 嘉荫县| 阿拉善左旗| 长垣县| 通河县| 大同市| 阿图什市| 修文县| 封开县| 武强县| 镇雄县| 宣恩县| 磴口县| 英吉沙县| 新密市| 子长县| 荣成市| 陆良县| 鲜城| 潜山县|