您好,登錄后才能下訂單哦!
這篇文章主要介紹如何解決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++多重繼承引發的重復調用的問題”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。