這篇文章主要介紹如何解決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++多重繼承引發的重復調用的問題”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯網站建設公司行業資訊頻道!
另外有需要云服務器可以了解下創新互聯建站vcdvsql.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
網站標題:如何解決C++多重繼承引發的重復調用的問題-創新互聯
標題鏈接:http://vcdvsql.cn/article8/cdecop.html
成都網站建設公司_創新互聯,為您提供網站營銷、定制開發、企業建站、用戶體驗、營銷型網站建設、外貿網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯