这篇文章主要介绍如何解决C++多重继承引发的重复调用的问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
创新互联成立与2013年,是专业互联网技术服务公司,拥有项目成都网站设计、成都网站制作网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元沧县做网站,已为上家服务,为沧县各地企业和个人服务,联系电话:13518219792分析一个多重继承引发的重复调用问题,先来看看问题代码:
#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++多重继承引发的重复调用的问题”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联网站建设公司行业资讯频道!
另外有需要云服务器可以了解下创新互联建站www.executivehouseboatcharters.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
网站标题:如何解决C++多重继承引发的重复调用的问题-创新互联
标题链接:/article8/cdecop.html
成都网站建设公司_创新互联,为您提供网站营销、定制开发、企业建站、用户体验、营销型网站建设、外贸网站建设
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联