时间:2021-05-20
本文实例讲述了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++程序设计有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
super是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是如果使用多继承,会涉及到查找顺序(MRO)、重复调用(钻石继承)等种种问
描述super()函数是用于调用父类(超类)的一个方法。super是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是如果使用多继承,
描述super()函数用于调用下一个父类(超类)并返回该父类实例的方法。super是用来解决多重继承问题的,直接用类名调用父类方法在使用单继承的时候没问题,但是
本文实例讲述了C++实现的多重继承功能。分享给大家供大家参考,具体如下:多重继承1.多重继承即一个类继承了多个基类的属性。2.多重继承下派生类的构造函数必须同时
问题你要写C扩展来读取来自任何Python类文件对象中的数据(比如普通文件、StringIO对象等)。解决方案要读取一个类文件对象的数据,你需要重复调用read