C++私有繼承(二)
文章轉(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)加密功能,簡(jiǎn)單講解了DES加密的相關(guān)概念,并結(jié)合實(shí)例形式分析了DES加密的具體實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-05-05C++利用模板實(shí)現(xiàn)消息訂閱和分發(fā)功能
C++語(yǔ)言支持重載,模板,虛函數(shù)等特性,為編寫高性能可擴(kuò)展的程序提供了利器。本文就講利用模板實(shí)現(xiàn)消息訂閱和分發(fā)功能,感興趣的小伙伴可以了解一下2022-12-12C語(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)鍵路徑、最短路徑),需要的朋友可以參考下2015-08-08淺談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數(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