欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++私有繼承(三)

 更新時間:2022年02月03日 11:39:50   作者:梁唐  
這篇文章主要介紹了C++私有繼承(三),前面的文章我們已經(jīng)介紹過了C++私有繼承(一)和(二),下面小編就繼續(xù)基于之前的內(nèi)容繼續(xù)向大家介紹C++私有繼承,具有一定的參考價值,需要的小伙伴可以參考一下

文章轉(zhuǎn)自公眾號:Coder梁(ID:Coder_LT)

C++私有繼承(一)

C++私有繼承(二)

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::minvalarray::max就變得可用了,就好像是Student的公有方法一樣:

cout << ada[i].max() << endl;

這里要注意,using聲明只使用方法名,沒有圓括號、函數(shù)特征表和返回類型。

到此這篇關(guān)于C++私有繼承(三)的文章就介紹到這了,更多相關(guān)C++私有繼承內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入理解Qt信號槽機制

    深入理解Qt信號槽機制

    信號槽是 Qt 框架引以為豪的機制之一。本文主要介紹了Qt信號槽機制,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • C指針原理教程之Ncurses介紹

    C指針原理教程之Ncurses介紹

    Ncurses 提供字符終端處理庫,包括面板和菜單。為了能夠使用ncurses庫,您必須在您的源程序中將curses.h包括(include)進來,而且在編譯的需要與它連接起來. 在gcc中您可以使用參數(shù)-lcurses進行編譯.
    2019-02-02
  • windows下如何安裝OpenCL

    windows下如何安裝OpenCL

    這篇文章主要介紹了windows下如何安裝OpenCL,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05
  • C語言動態(tài)內(nèi)存分配和內(nèi)存操作函數(shù)使用詳解

    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-12
  • 用C語言程序判斷大小端模式

    用C語言程序判斷大小端模式

    本文介紹了用C語言程序判斷大小端的方法,與大家分享一下。
    2013-04-04
  • C++實現(xiàn)LeetCode(110.平衡二叉樹)

    C++實現(xiàn)LeetCode(110.平衡二叉樹)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(110.平衡二叉樹),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • Prim(普里姆)算法求最小生成樹的思想及C語言實例講解

    Prim(普里姆)算法求最小生成樹的思想及C語言實例講解

    Prim算法能夠在帶權(quán)的圖中搜索出最小生成樹,這也是各大ACM和面試及考研題目中的熱點,下面我們就來詳細看一下Prim(普里姆)算法求最小生成樹的思想及C語言實例講解
    2016-06-06
  • Opencv實現(xiàn)綠幕視頻背景替換功能

    Opencv實現(xiàn)綠幕視頻背景替換功能

    這篇文章主要為大家詳細介紹了Opencv實現(xiàn)綠幕視頻背景替換功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • C語言字符串的模式匹配之BF與KMP

    C語言字符串的模式匹配之BF與KMP

    這篇文章記錄一下串里面的模式匹配,模式匹配,顧名思義就是給定一個被匹配的字符串,然后用一個字符串模式(模型)去匹配上面說的字符串,看后者是否在前者里面出現(xiàn)。常用的有2種算法可以實現(xiàn),下面我們來具體探討下
    2021-09-09
  • 編輯器寫C語言輸出中文亂碼問題及解決

    編輯器寫C語言輸出中文亂碼問題及解決

    這篇文章主要介紹了編輯器寫C語言輸出中文亂碼問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09

最新評論