C++多重继承引发的重复调用问题与解决方法

 更新时间:2018年05月15日 10:30:25   作者:止语---  
这篇文章主要介绍了C++多重继承引发的重复调用问题与解决方法,结合具体实例形式分析了C++多重调用中的重复调用问题及相应的解决方法,需要的朋友可以参考下

本文实例讲述了C++多重继承引发的重复调用问题与解决方法。分享给大家供大家参考,具体如下:

前面简单介绍了一个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++程序设计有所帮助。

相关文章

  • 使用c++编程实现简单的打字小游戏

    使用c++编程实现简单的打字小游戏

    这篇文章主要为大家介绍了使用c++编程语言来实现一个非常简单的打字小游戏过程实现的示例代码,有需要的朋友可以借鉴参考下,希望能够有所帮助
    2021-10-10
  • C语言中strlen()函数的使用详解

    C语言中strlen()函数的使用详解

    strlen函数是用来求字符串长度的函数,这个函数遇到‘\0’就会停止,且这个长度不包含‘\0’,这篇文章给大家介绍了C语言中strlen()函数的使用,感兴趣的朋友一起看看吧
    2024-02-02
  • C语言数据结构之堆排序的优化算法

    C语言数据结构之堆排序的优化算法

    堆排序Heap Sort就是利用堆进行排序的方法,下面这篇文章主要给大家介绍了关于C语言数据结构之堆排序的优化算法的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • C++自动析构时的顺序问题

    C++自动析构时的顺序问题

    这篇文章主要介绍了C++自动析构时的顺序,通过实例代码给大家讲解了C++ 构造与析构的执行顺序,代码简单易懂,非常不错对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • 用C++实现DBSCAN聚类算法

    用C++实现DBSCAN聚类算法

    本篇文章是对使用C++实现DBSCAN聚类算法的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 解析鸿蒙轻内核静态内存的使用

    解析鸿蒙轻内核静态内存的使用

    摘要:静态内存实质上是一个静态数组,静态内存池内的块大小在初始化时设定,初始化后块大小不可变更。静态内存池由一个控制块和若干相同大小的内存块构成。控制块位于内存池头部,用于内存块管理。内存块的申请和释放以块大小为粒度
    2021-06-06
  • 解决不用sizeof求出int大小的方法

    解决不用sizeof求出int大小的方法

    本篇文章是对不用sizeof求出int大小的方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C语言实现房屋管理系统

    C语言实现房屋管理系统

    这篇文章主要为大家详细介绍了C语言实现房屋管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-12-12
  • C语言单链表的图文示例讲解

    C语言单链表的图文示例讲解

    单链表是链表的其中一种基本结构。一个最简单的结点结构如图所示,它是构成单链表的基本结点结构。在结点中数据域用来存储数据元素,指针域用于指向下一个具有相同结构的结点。 因为只有一个指针结点,称为单链表
    2023-02-02
  • C++中COM组件初始化方法实例分析

    C++中COM组件初始化方法实例分析

    这篇文章主要介绍了C++中COM组件初始化方法,涉及C++中COM组件的使用技巧,需要的朋友可以参考下
    2015-05-05

最新评论