C++私有繼承(三)
文章轉(zhuǎn)自公眾號:Coder梁(ID:Coder_LT)
1.私有繼承
通過私有繼承,我們可以實現(xiàn)一種has-a
的關(guān)系。
但前文當(dāng)中我們也曾說過,通過包含對象我們一樣可以實現(xiàn)has-a的關(guān)系,那么在我們進行編碼的時候,究竟應(yīng)該使用哪一種呢?
根據(jù)C++ Primer
中的闡述,大多數(shù)程序員會更傾向于使用包含,因為這更加容易理解。類聲明當(dāng)中包含對象,我們可以在成員函數(shù)當(dāng)中直接使用,這顯然更加直觀,而使用繼承的方式則非常地抽象。
其次,多個基類繼承的時候,也可能會引起一些問題。比如包含同名方法的獨立基類,或者是擁有共同祖先的獨立基類等等。另外,使用私有繼承只能使用一個父類對象,而通過包含的方式可以使用任意多個對象。
但私有繼承的方式也有一些特有的優(yōu)點,比如說可以在派生類當(dāng)中使用基類的保護成員,但如果是包含的話,就沒辦法使用這些保護成員或者方法了。另外,派生類可以重新定義虛函數(shù),而包含類的方式不行。
只能說通常我們要實現(xiàn)has-a
的包含關(guān)系,應(yīng)該使用包含類對象的方式,但在一些特殊場景當(dāng)中,也許使用繼承是更好的選擇。
2.保護繼承
保護繼承是私有繼承的變體,保護繼承在列出基類時使用關(guān)鍵字protected:
class Student : protected std::string, protected std::valarray<double> { ? ? ... };
使用保護繼承時,基類的公有成員和保護成員都會成為派生類的保護成員。
和私有繼承一樣,基類的接口在派生類當(dāng)中也是可用的,但在繼承層次結(jié)構(gòu)之外是不可用的。當(dāng)我們從派生類繼續(xù)派生出第三代類的時候,私有繼承和保護繼承的區(qū)別就出來了。使用私有繼承時,第三代類不能使用基類的接口,因為基類的公有方法在派生類當(dāng)中變成了私有方法。而使用保護繼承的話,基類的公有方法在派生類變成受保護的,所以第三代派生類依然可以使用。
3.使用using重新定義訪問權(quán)限
使用保護派生或者是私有派生時,基類的公有成員將會變成保護成員或者是私有成員。
假設(shè)要想讓基類的方法在派生類外部可用,方法之一是單獨開發(fā)一個派生類方法,在這個方法當(dāng)中調(diào)用基類的方法。比如假設(shè)希望Student
類能夠使用valarray類的sum方法,一個做法是在Student中聲明一個sum方法,然后在這個方法當(dāng)中調(diào)用valarray
類的sum方法:
double Student::sum() const { ? ? return std::valarray<double>::sum(); }
另外一種方法是將調(diào)用函數(shù)包裝在另外一個函數(shù)的調(diào)用中,即使用using聲明,來指出派生類可以使用特定的基類成員。
比如假設(shè)我們希望Student
類能夠使用valarray
的sum和max方法,我們可以在student.h的公有部分加上using聲明:
class Student : private std::string, private std::valarray<double> { ? ?public: ? ? ?using std::valarray<double>::min; ? ? ?using std::valarray<double>::max; ? ? ... };
這樣一來,valarray::min
和valarray::max
就變得可用了,就好像是Student的公有方法一樣:
cout << ada[i].max() << endl;
這里要注意,using聲明只使用方法名,沒有圓括號、函數(shù)特征表和返回類型。
到此這篇關(guān)于C++私有繼承(三)的文章就介紹到這了,更多相關(guān)C++私有繼承內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言動態(tài)內(nèi)存分配和內(nèi)存操作函數(shù)使用詳解
但是在實際的編程中,往往會發(fā)生這種情況,即所需的內(nèi)存空間取決于實際輸入的數(shù)據(jù),而無法預(yù)先確定 。為了解決上述問題,C語言提供了一些內(nèi)存管理函數(shù),這些內(nèi)存管理函數(shù)可以按需要動態(tài)的分配內(nèi)存空間,也可把不再使用的空間回收再次利用2022-12-12C++實現(xiàn)LeetCode(110.平衡二叉樹)
這篇文章主要介紹了C++實現(xiàn)LeetCode(110.平衡二叉樹),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07