C++引用和結(jié)構(gòu)體介紹
文章轉(zhuǎn)自微信公眾號(hào):Coder梁(ID:Coder_LT)
結(jié)構(gòu)體是我們自定義的復(fù)合類(lèi)型,本質(zhì)上也是一種變量類(lèi)型,所以一樣可以使用引用。傳遞結(jié)構(gòu)體引用的方式和其他變量一樣:
struct P {
int x, y;
};
void set_axis(P& a, P& b);
前文C++引用的使用與const修飾符當(dāng)中也曾說(shuō)過(guò),雖然引用在基本類(lèi)型上一樣適用,但一般在實(shí)際使用當(dāng)中,不在基本變量類(lèi)型上使用引用。倒不是有什么問(wèn)題,而是沒(méi)有必要,畢竟基本變量類(lèi)型占據(jù)的內(nèi)存太小了,值傳遞和引用傳遞帶來(lái)的差別幾乎可以忽略不計(jì)。
因此使用得比較多的就是引用傳遞結(jié)構(gòu)體,因?yàn)榻Y(jié)構(gòu)體當(dāng)中的成員變量往往比較復(fù)雜,通過(guò)引用傳遞可以避免結(jié)構(gòu)體的整體拷貝,可以節(jié)省時(shí)間和內(nèi)存。
不僅如此,我們還可以通過(guò)函數(shù)返回引用:
P& return_ref(P& a);
返回引用的目的和傳遞引用參數(shù)的目的是一樣的,為了節(jié)省時(shí)間和內(nèi)存。
如果函數(shù)返回的不是引用,而是結(jié)構(gòu)體的值的話,調(diào)用代碼可能是這樣的:
P m = return_ref(a);
return_ref這個(gè)函數(shù)的返回結(jié)果會(huì)先賦值到一個(gè)臨時(shí)的位置,然后再?gòu)?fù)制給m。這和我們傳遞結(jié)構(gòu)體參數(shù)的開(kāi)銷(xiāo)是一樣的,如果我們返回的類(lèi)型是引用,那么則可以節(jié)省掉這個(gè)開(kāi)銷(xiāo)。
但是,這里有一個(gè)坑。
我們通過(guò)函數(shù)返回的引用,不能是函數(shù)終止時(shí)就不存在的內(nèi)存單元,也就是不能是臨時(shí)變量。
比如下面這個(gè)例子就是不行的:
P& return_ref(P& a) {
P cur = a;
return cur;
}
我們?cè)诤瘮?shù)當(dāng)中將傳入的結(jié)構(gòu)體a拷貝了一份,對(duì)這個(gè)拷貝體進(jìn)行了返回。這樣的代碼從邏輯上看是沒(méi)有問(wèn)題的,但問(wèn)題是我們創(chuàng)建的cur是一個(gè)臨時(shí)變量,當(dāng)函數(shù)返回的時(shí)候就會(huì)被銷(xiāo)毀,不再存在,于是就會(huì)導(dǎo)致一些未知的錯(cuò)誤。
所以如果要使用函數(shù)返回引用的話,一定要返回外部傳入的引用或者全局變量的引用,而不能在函數(shù)內(nèi)部臨時(shí)創(chuàng)建。
除此之外,返回引用還有另外一個(gè)坑點(diǎn),我們來(lái)看代碼:
P a,b; return_ref(a) = b;
這樣的語(yǔ)法是被允許的,因?yàn)?code>return_ref函數(shù)返回的是一個(gè)引用,我們當(dāng)然可以對(duì)一個(gè)引用的值進(jìn)行修改。有的情況下這一樣會(huì)產(chǎn)生問(wèn)題,如果你不想要這樣的情況被允許,也有辦法,我們可以使用const關(guān)鍵字,
將返回的結(jié)果限制成不可修改:
const P& return_ref(P& a);
到此這篇關(guān)于C++引用和結(jié)構(gòu)體介紹的文章就介紹到這了,更多相關(guān)C++引用和結(jié)構(gòu)體內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言使用DP動(dòng)態(tài)規(guī)劃思想解最大K乘積與乘積最大問(wèn)題
Dynamic Programming動(dòng)態(tài)規(guī)劃方法采用最優(yōu)原則來(lái)建立用于計(jì)算最優(yōu)解的遞歸式,并且考察每個(gè)最優(yōu)決策序列中是否包含一個(gè)最優(yōu)子序列,這里我們就來(lái)展示C語(yǔ)言使用DP動(dòng)態(tài)規(guī)劃思想解最大K乘積與乘積最大問(wèn)題2016-06-06
使用Libmicrohttpd搭建內(nèi)嵌(本地)服務(wù)器的方法
下面小編就為大家?guī)?lái)一篇使用Libmicrohttpd搭建內(nèi)嵌(本地)服務(wù)器的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-08-08
C++消息隊(duì)列(定義,結(jié)構(gòu),如何創(chuàng)建,發(fā)送與接收)
這篇文章主要介紹了C++消息隊(duì)列(定義,結(jié)構(gòu),如何創(chuàng)建,發(fā)送與接收),消息隊(duì)列是一種先進(jìn)先出的隊(duì)列型數(shù)據(jù)結(jié)構(gòu),實(shí)際上是系統(tǒng)內(nèi)核中的一個(gè)內(nèi)部鏈表2022-08-08
C++實(shí)現(xiàn)LeetCode(99.復(fù)原二叉搜索樹(shù))
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(99.復(fù)原二叉搜索樹(shù)),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++類(lèi)模板實(shí)戰(zhàn)之vector容器的實(shí)現(xiàn)
本文我們將做一個(gè)類(lèi)模板實(shí)戰(zhàn)-手寫(xiě)精簡(jiǎn)版vector容器。讓我們自己封裝一個(gè)數(shù)組類(lèi),可以適應(yīng)基本數(shù)據(jù)類(lèi)型和自定義數(shù)據(jù)類(lèi)型,感興趣的可以了解一下2022-07-07
C語(yǔ)言實(shí)現(xiàn)2048游戲(ege圖形庫(kù)版)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)2048游戲,ege圖形庫(kù)版,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12

