C++中友元函數(shù)(friend)解析
文章轉(zhuǎn)自公眾號(hào):Coder梁(ID:Coder_LT)
我們知道C++控制對(duì)象的私有部分的訪問(wèn),只能通過(guò)公共的接口。這樣的設(shè)計(jì)當(dāng)然沒(méi)錯(cuò),但有的時(shí)候也會(huì)顯得過(guò)于嚴(yán)格,產(chǎn)生一些問(wèn)題。
因此C++提供了另外一種形式的訪問(wèn)權(quán)限,叫做友元(friend)。
友元有三種,分別是友元函數(shù)、友元類和友元成員函數(shù)。
通過(guò)讓函數(shù)成為類的友元,可以賦予該函數(shù)與類成員函數(shù)一樣的訪問(wèn)權(quán)限,也就是說(shuō)我們可以在友元函數(shù)當(dāng)中訪問(wèn)類的私有成員變量。
在介紹友元函數(shù)的使用之前,我們需要先了解為什么需要友元函數(shù)。C++ Primer中給了一個(gè)非常不錯(cuò)的例子,在之前運(yùn)算符重載的例子當(dāng)中,我們實(shí)現(xiàn)了一個(gè)類Time。用來(lái)記錄時(shí)間,假設(shè)我們需要重載它的*運(yùn)算符,能夠允許一個(gè)時(shí)間對(duì)象和一個(gè)浮點(diǎn)數(shù)相乘。
很明顯,我們只需要重載運(yùn)算符*即可:
Time Time::operator*(const double x) {
? ? // todo
}我們?cè)谑褂玫臅r(shí)候大概是這樣:
Time a, b; a = b * 32.5;
但是這里有一個(gè)小問(wèn)題,我們寫(xiě)成a = b * 32.5;可以,但如果反過(guò)來(lái)寫(xiě)成32.5 * b就不行了。因?yàn)閷?duì)于b * 32.5來(lái)說(shuō)本質(zhì)上是b調(diào)用了operator*函數(shù),等價(jià)于a = b.opeartor*(32.5);。但后者就不行了,要怎么解決呢,只能另外實(shí)現(xiàn)一個(gè)函數(shù)來(lái)解決了,這個(gè)函數(shù)有兩個(gè)input,分別是double和Time類型,返回一個(gè)Time類型。
Time operator*(double m, const Time &t);
但這又有了新的問(wèn)題,由于這不是一個(gè)成員函數(shù),不能直接訪問(wèn)類的私有數(shù)據(jù)。為了破例讓它能夠訪問(wèn),我們需要將它設(shè)置成友元。
創(chuàng)建友元的方法很簡(jiǎn)單,我們只需要在函數(shù)簽名之前加上關(guān)鍵字friend。
friend Time operator*(double m, const Time &t);
它有兩個(gè)含義:
- 它不是成員函數(shù),因此不能使用成員函數(shù)運(yùn)算符來(lái)調(diào)用
- 它與成員函數(shù)的訪問(wèn)權(quán)限相同,即可以訪問(wèn)所有
private和public數(shù)據(jù)
由于友元函數(shù)不是成員函數(shù),所有我們?cè)趯?shí)現(xiàn)的時(shí)候不需要使用Time::限定符,也不用在實(shí)現(xiàn)當(dāng)中加上關(guān)鍵字friend,
函數(shù)的實(shí)現(xiàn)如下:
Time operator*(double m, const Time &t) {
? ? Time result;
? ? long totalminutes = t.hours * m * 60 + t.minutes * m;
? ? result.hours = totalminutes / 60;
? ? result.minutes = totalminutes % 60;
? ? return result;
}我們?cè)诤瘮?shù)當(dāng)中直接訪問(wèn)了hours和minutes成員變量,因此函數(shù)必須是友元函數(shù)。
當(dāng)然我們可以把函數(shù)稍微變換一下,就可以不必是友元函數(shù)了:
Time operator*(double m, const Time &t) {
? ? return t * m; // ?調(diào)用了t.operator*(m)
}在這個(gè)函數(shù)當(dāng)中,我們沒(méi)有顯式地訪問(wèn)私有變量,因此可以不必是友元。
到此這篇關(guān)于C++友元函數(shù)講解的文章就介紹到這了,更多相關(guān)C++友元函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C/C++?Qt數(shù)據(jù)庫(kù)與SqlTableModel組件應(yīng)用教程
SqlTableModel?組件可以將數(shù)據(jù)庫(kù)中的特定字段動(dòng)態(tài)顯示在TableView表格組件中,這篇文章將主要介紹SqlTableModel組件一些常用的操作,需要的朋友可以參考一下2021-12-12
C語(yǔ)言實(shí)現(xiàn)24點(diǎn)問(wèn)題詳解
24點(diǎn)問(wèn)題就是在屏幕上輸入1?10范圍內(nèi)的4個(gè)整數(shù)(可以有重復(fù)),對(duì)它們進(jìn)行加、減、乘、除四則運(yùn)算后(可以任意的加括號(hào)限定計(jì)算的優(yōu)先級(jí)),尋找計(jì)算結(jié)果等于24的表達(dá)式。本文將通過(guò)C語(yǔ)言實(shí)現(xiàn)24點(diǎn)問(wèn)題的求解,需要的可以參考一下2021-12-12
C語(yǔ)言的字符函數(shù)和字符串函數(shù)詳解
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言的字符函數(shù)和字符串函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-03-03
C/C++中文件的隨機(jī)讀寫(xiě)詳解及其作用介紹
這篇文章主要介紹了C/C++中文件的隨機(jī)讀寫(xiě)詳解及其作用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
C++語(yǔ)言const 關(guān)鍵字使用方法圖文詳解
在類中,如果你不希望某些數(shù)據(jù)被修改,可以使用const關(guān)鍵字加以限定。const 可以用來(lái)修飾成員變量、成員函數(shù)以及對(duì)象2020-01-01
C語(yǔ)言利用模板實(shí)現(xiàn)簡(jiǎn)單的棧類
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言利用模板實(shí)現(xiàn)簡(jiǎn)單的棧類,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12
C語(yǔ)言超詳細(xì)分析多進(jìn)程的概念與使用
在一個(gè)項(xiàng)目中并發(fā)執(zhí)行任務(wù)時(shí)多數(shù)情況下都會(huì)選擇多線程,但有時(shí)候也會(huì)選擇多進(jìn)程,例如可以同時(shí)運(yùn)行n個(gè)記事本編輯不同文本,由一個(gè)命令跳轉(zhuǎn)到另外一個(gè)命令,或者使用不同進(jìn)程進(jìn)行協(xié)作2022-08-08

