91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

如何解決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

淮南市| 桦川县| 彭州市| 宜宾县| 雅安市| 永修县| 樟树市| 嵊泗县| 唐海县| 鹤庆县| 浙江省| 彰武县| 韶关市| 依兰县| 米脂县| 普陀区| 东安县| 博客| 建湖县| 牟定县| 朝阳县| 喜德县| 正宁县| 津南区| 鄂托克前旗| 通榆县| 贺州市| 红安县| 资溪县| 利津县| 怀安县| 富平县| 汶川县| 鸡西市| 东乡族自治县| 北川| 修武县| 威宁| 金华市| 贡觉县| 维西|