您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關C++中繼承方式和訪問限定符有什么關系的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
繼承方式和訪問限定符的關系
三種繼承方式:
公有繼承
私有繼承
保護繼承
關系:若基類的成員函數為私有,則派生類對基類的私有成員是不可見的,其他的標準為選范圍小的為最終訪問限定。
保護成員限定符:一些基類成員不想被基類的對象直接訪問,但需要在派生類中才能訪問,就定義為保護成員。保護成員限定符是因繼承才出現的。
理解隱藏
隱藏是指派生類的函數屏蔽了與其同名的基類函數。規則如下:
如果派生類的函數與基類的函數同名,但是參數不同,此時,不論有無virtual關鍵字,基類的函數將被隱藏。
如果派生類的函數與基類的函數同名,并且參數也相同,但是基類函數沒有virtual關鍵字,此時,基類的函數被隱藏。
派生類的默認成員函數
在派生類中如果沒有顯示定義一下六個默認成員函數,編譯系統會默認合成這六個成員函數。
構造函數
拷貝構造函數
析構函數
賦值操作符重載
取地址操作符重載
const修飾的取地址操作符重載
#include<iostream> using namespace std; class person{ public: person(const char* name) :_name(name) { cout<<"person()"<<endl; } person(const person& p){ cout<<"person(const person& p)"<<endl; } person& operator=(const person& p){ cout<<"person& operator=(const person& p)"<<endl; if(this!=&p){ _name=p._name; } return *this; } ~person(){ cout<<"~person()"<<endl; } protected: string _name; }; class student:public person{ public: student(const char* name,int num) :person(name) ,_num(num){ cout<<"student()"<<endl; } student(const student& s) :person(s) ,_num(s._num) { cout<<"student(const student& s)"<<endl; } student& operator=(const student& s){ cout<<"student& operator=(const student& p)"<<endl; if(this!=&s){ person::operator=(s);//必須指定域,否則會死循環 _num=s._num; } return *this; } ~student(){//析構的時候先清理子類,再清理父類,不需要顯示的調用 cout<<"~student()"<<endl; } private: int _num; }; int main(){ student s1("jack",18); student s2(s1); student s3("rose",16); s1=s3; }
菱形繼承
菱形繼承存在二義性以及數據冗余問題。
例,下圖中繼承的數據為兩份,各不相同:
解決方法:虛繼承
在菱形的第二層添加virtual
例:
感謝各位的閱讀!關于“C++中繼承方式和訪問限定符有什么關系”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。