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

C++私有繼承(二)

 更新時(shí)間:2022年01月23日 17:18:44   作者:?梁唐  
這篇文章主要介紹了C++私有繼承,在私有繼承時(shí),基類的公有對(duì)象以及保護(hù)對(duì)象會(huì)變成派生類的私有對(duì)象。我們可以在派生類方法當(dāng)中使用它,但無(wú)法通過(guò)派生類對(duì)象直接調(diào)用,但無(wú)法訪問(wèn)基類的私有方法和對(duì)象,下面具體內(nèi)容,需要的朋友可以參考一下

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

我們繼續(xù)上一篇文章來(lái)看私有繼承。

1.訪問(wèn)基類方法

我們知道,在私有繼承時(shí),基類的公有對(duì)象以及保護(hù)對(duì)象會(huì)變成派生類的私有對(duì)象。我們可以在派生類方法當(dāng)中使用它,但無(wú)法通過(guò)派生類對(duì)象直接調(diào)用,但無(wú)法訪問(wèn)基類的私有方法和對(duì)象。

這個(gè)概念我們很好理解,但具體到實(shí)現(xiàn)上,我們?nèi)绾卧谂缮惖姆椒ó?dāng)中調(diào)用基類的公有或者保護(hù)方法呢?

比如,在之前的類聲明當(dāng)中我們聲明了一個(gè)Average方法,用來(lái)計(jì)算學(xué)生考試成績(jī)的平均分。由于Student類是繼承了valarray類,而非包含一個(gè)valarray的實(shí)例,那么我們?nèi)绾卧?code>Average方法的實(shí)現(xiàn)當(dāng)中調(diào)用valarray的公有方法呢?

答案是通過(guò)解析運(yùn)算符和類名調(diào)用

double Student::Average() const {
? ? if (ArrayDb::size() > 0) {
? ? ? ? return ArrayDb::sum() / ArrayDb::size();
? ? }
? ? return 0;
}

2.訪問(wèn)基類對(duì)象

現(xiàn)在我們知道了使用解析運(yùn)算符可以訪問(wèn)基類的方法,但問(wèn)題又來(lái)了,如果我們要訪問(wèn)的不再是基類的方法而是基類對(duì)象本身,那么我們應(yīng)該怎么辦呢?

比如同樣例子當(dāng)中我們有一個(gè)Name方法,需要返回學(xué)生的姓名。由于Student類只是繼承了string類并沒有自己的string實(shí)例,因此我們需要返回基類對(duì)象本身。

同樣,我們?cè)趺床僮髂兀?/p>

答案是使用強(qiáng)制轉(zhuǎn)換。

const string& Student::Name() const {
? ? return (const string&) *this;
}

因?yàn)?code>Student類是從string類中派生而來(lái),所以我們是可以將Student對(duì)象強(qiáng)制轉(zhuǎn)換成string對(duì)象的。

3.訪問(wèn)基類的友元

方法和對(duì)象都好辦,但友元怎么辦呢?因?yàn)橛言瘮?shù)并不屬于類,所以無(wú)法通過(guò)類名或者解析運(yùn)算符搞定。針對(duì)這種情況,我們只能取巧,通過(guò)顯式地對(duì)派生類進(jìn)行類型轉(zhuǎn)換實(shí)現(xiàn)。

例如:

ostream & operator<<(ostream& os, const Student& stu) {
? ? os << "Scores for " << (const string&) stu << ":\n";
}

在這個(gè)方法當(dāng)中,我們顯式地將stu實(shí)例轉(zhuǎn)變成了基類string的類型,這樣就可以調(diào)用基類string的友元了。

引用不會(huì)自動(dòng)發(fā)生轉(zhuǎn)換,是因?yàn)樵谒接欣^承當(dāng)中,在不進(jìn)行顯式類型轉(zhuǎn)換的情況下,不能將派生類的引用或指針賦給基類的引用或指針。

那么問(wèn)題來(lái)了,如果我們使用的是公有繼承,那么是不是就可以了呢?

答案是依然不行。

原因也簡(jiǎn)單,首先在不使用類型轉(zhuǎn)換的情況下,os << stu和自身的友元函數(shù)類型匹配, 將會(huì)發(fā)生遞歸。其次由于C++支持多繼承,所以編譯器將會(huì)無(wú)法確定轉(zhuǎn)換成哪個(gè)基類的類型。因此還是需要我們手動(dòng)進(jìn)行強(qiáng)制類型轉(zhuǎn)換。

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

相關(guān)文章

  • C語(yǔ)言使用openSSL庫(kù)DES模塊實(shí)現(xiàn)加密功能詳解

    C語(yǔ)言使用openSSL庫(kù)DES模塊實(shí)現(xiàn)加密功能詳解

    這篇文章主要介紹了C語(yǔ)言使用openSSL庫(kù)DES模塊實(shí)現(xiàn)加密功能,簡(jiǎn)單講解了DES加密的相關(guān)概念,并結(jié)合實(shí)例形式分析了DES加密的具體實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-05-05
  • C++利用模板實(shí)現(xiàn)消息訂閱和分發(fā)功能

    C++利用模板實(shí)現(xiàn)消息訂閱和分發(fā)功能

    C++語(yǔ)言支持重載,模板,虛函數(shù)等特性,為編寫高性能可擴(kuò)展的程序提供了利器。本文就講利用模板實(shí)現(xiàn)消息訂閱和分發(fā)功能,感興趣的小伙伴可以了解一下
    2022-12-12
  • C語(yǔ)言 聯(lián)合(union)用法案例詳解

    C語(yǔ)言 聯(lián)合(union)用法案例詳解

    這篇文章主要介紹了C語(yǔ)言 聯(lián)合(union)用法案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C++封裝IATHOOK類實(shí)例

    C++封裝IATHOOK類實(shí)例

    這篇文章主要介紹了C++封裝IATHOOK類的實(shí)現(xiàn)方法,對(duì)IAT的HOOK實(shí)例進(jìn)行了封裝,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2014-10-10
  • C語(yǔ)言Easyx實(shí)現(xiàn)貪吃蛇詳解

    C語(yǔ)言Easyx實(shí)現(xiàn)貪吃蛇詳解

    這篇文章主要為大家詳細(xì)介紹了基于easyx的C++實(shí)現(xiàn)貪吃蛇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • 詳解圖的應(yīng)用(最小生成樹、拓?fù)渑判?、關(guān)鍵路徑、最短路徑)

    詳解圖的應(yīng)用(最小生成樹、拓?fù)渑判?、關(guān)鍵路徑、最短路徑)

    這篇文章主要介紹了圖的應(yīng)用(最小生成樹、拓?fù)渑判?、關(guān)鍵路徑、最短路徑),需要的朋友可以參考下
    2015-08-08
  • C++11中使用using的方法

    C++11中使用using的方法

    在 C++ 中 using 用于聲明命名空間,使用命名空間也可以防止命名沖突。這篇文章主要介紹了C++11中使用using的方法,需要的朋友可以參考下
    2021-09-09
  • 淺談C++內(nèi)存分配及變長(zhǎng)數(shù)組的動(dòng)態(tài)分配

    淺談C++內(nèi)存分配及變長(zhǎng)數(shù)組的動(dòng)態(tài)分配

    下面小編就為大家?guī)?lái)一篇淺談C++內(nèi)存分配及變長(zhǎng)數(shù)組的動(dòng)態(tài)分配。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-09-09
  • C++中的繼承模式深入詳解

    C++中的繼承模式深入詳解

    這篇文章主要介紹了C++中的繼承模式深入詳解。繼承是OOP設(shè)計(jì)中的重要概念。在C++語(yǔ)言中,派生類繼承基類有三種繼承方式:私有繼承(private)、保護(hù)繼承(protected)和公有繼承(public)。
    2021-03-03
  • 數(shù)據(jù)結(jié)構(gòu) 雙機(jī)調(diào)度問(wèn)題的實(shí)例詳解

    數(shù)據(jù)結(jié)構(gòu) 雙機(jī)調(diào)度問(wèn)題的實(shí)例詳解

    這篇文章主要介紹了數(shù)據(jù)結(jié)構(gòu) 雙機(jī)調(diào)度問(wèn)題的實(shí)例詳解的相關(guān)資料,雙機(jī)調(diào)度問(wèn)題,又稱獨(dú)立任務(wù)最優(yōu)調(diào)度:用兩臺(tái)處理機(jī)A和B處理n個(gè)作業(yè)的實(shí)例,需要的朋友可以參考下
    2017-08-08

最新評(píng)論