亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++私有繼承(三)

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

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

C++私有繼承(一)

C++私有繼承(二)

1.私有繼承

通過(guò)私有繼承,我們可以實(shí)現(xiàn)一種has-a的關(guān)系。

但前文當(dāng)中我們也曾說(shuō)過(guò),通過(guò)包含對(duì)象我們一樣可以實(shí)現(xiàn)has-a的關(guān)系,那么在我們進(jìn)行編碼的時(shí)候,究竟應(yīng)該使用哪一種呢?

根據(jù)C++ Primer中的闡述,大多數(shù)程序員會(huì)更傾向于使用包含,因?yàn)檫@更加容易理解。類聲明當(dāng)中包含對(duì)象,我們可以在成員函數(shù)當(dāng)中直接使用,這顯然更加直觀,而使用繼承的方式則非常地抽象。

其次,多個(gè)基類繼承的時(shí)候,也可能會(huì)引起一些問(wèn)題。比如包含同名方法的獨(dú)立基類,或者是擁有共同祖先的獨(dú)立基類等等。另外,使用私有繼承只能使用一個(gè)父類對(duì)象,而通過(guò)包含的方式可以使用任意多個(gè)對(duì)象。

但私有繼承的方式也有一些特有的優(yōu)點(diǎn),比如說(shuō)可以在派生類當(dāng)中使用基類的保護(hù)成員,但如果是包含的話,就沒(méi)辦法使用這些保護(hù)成員或者方法了。另外,派生類可以重新定義虛函數(shù),而包含類的方式不行。

只能說(shuō)通常我們要實(shí)現(xiàn)has-a的包含關(guān)系,應(yīng)該使用包含類對(duì)象的方式,但在一些特殊場(chǎng)景當(dāng)中,也許使用繼承是更好的選擇。

2.保護(hù)繼承

保護(hù)繼承是私有繼承的變體,保護(hù)繼承在列出基類時(shí)使用關(guān)鍵字protected:

class Student : protected std::string, protected std::valarray<double> {
? ? ...
};

使用保護(hù)繼承時(shí),基類的公有成員和保護(hù)成員都會(huì)成為派生類的保護(hù)成員。

和私有繼承一樣,基類的接口在派生類當(dāng)中也是可用的,但在繼承層次結(jié)構(gòu)之外是不可用的。當(dāng)我們從派生類繼續(xù)派生出第三代類的時(shí)候,私有繼承和保護(hù)繼承的區(qū)別就出來(lái)了。使用私有繼承時(shí),第三代類不能使用基類的接口,因?yàn)榛惖墓蟹椒ㄔ谂缮惍?dāng)中變成了私有方法。而使用保護(hù)繼承的話,基類的公有方法在派生類變成受保護(hù)的,所以第三代派生類依然可以使用。

3.使用using重新定義訪問(wèn)權(quán)限

使用保護(hù)派生或者是私有派生時(shí),基類的公有成員將會(huì)變成保護(hù)成員或者是私有成員。

假設(shè)要想讓基類的方法在派生類外部可用,方法之一是單獨(dú)開(kāi)發(fā)一個(gè)派生類方法,在這個(gè)方法當(dāng)中調(diào)用基類的方法。比如假設(shè)希望Student類能夠使用valarray類的sum方法,一個(gè)做法是在Student中聲明一個(gè)sum方法,然后在這個(gè)方法當(dāng)中調(diào)用valarray類的sum方法:

double Student::sum() const {
? ? return std::valarray<double>::sum();
}

另外一種方法是將調(diào)用函數(shù)包裝在另外一個(gè)函數(shù)的調(diào)用中,即使用using聲明,來(lái)指出派生類可以使用特定的基類成員。

比如假設(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;
? ? ...
};

這樣一來(lái),valarray::minvalarray::max就變得可用了,就好像是Student的公有方法一樣:

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

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

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

相關(guān)文章

  • 深入理解Qt信號(hào)槽機(jī)制

    深入理解Qt信號(hào)槽機(jī)制

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

    C指針原理教程之Ncurses介紹

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

    windows下如何安裝OpenCL

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

    C語(yǔ)言動(dòng)態(tài)內(nèi)存分配和內(nèi)存操作函數(shù)使用詳解

    但是在實(shí)際的編程中,往往會(huì)發(fā)生這種情況,即所需的內(nèi)存空間取決于實(shí)際輸入的數(shù)據(jù),而無(wú)法預(yù)先確定 。為了解決上述問(wèn)題,C語(yǔ)言提供了一些內(nèi)存管理函數(shù),這些內(nèi)存管理函數(shù)可以按需要?jiǎng)討B(tài)的分配內(nèi)存空間,也可把不再使用的空間回收再次利用
    2022-12-12
  • 用C語(yǔ)言程序判斷大小端模式

    用C語(yǔ)言程序判斷大小端模式

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

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

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

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

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

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

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

    C語(yǔ)言字符串的模式匹配之BF與KMP

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

    編輯器寫(xiě)C語(yǔ)言輸出中文亂碼問(wèn)題及解決

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

最新評(píng)論