文章轉(zhuǎn)自微信公眾號(hào):Coder梁(ID:Coder_LT)
結(jié)構(gòu)體是我們自定義的復(fù)合類型,本質(zhì)上也是一種變量類型,所以一樣可以使用引用。傳遞結(jié)構(gòu)體引用的方式和其他變量一樣:
1
2
3
4
5
|
struct P { int x, y; }; void set_axis(P& a, P& b); |
前文C++引用的使用與const修飾符當(dāng)中也曾說過,雖然引用在基本類型上一樣適用,但一般在實(shí)際使用當(dāng)中,不在基本變量類型上使用引用。倒不是有什么問題,而是沒有必要,畢竟基本變量類型占據(jù)的內(nèi)存太小了,值傳遞和引用傳遞帶來的差別幾乎可以忽略不計(jì)。
因此使用得比較多的就是引用傳遞結(jié)構(gòu)體,因?yàn)榻Y(jié)構(gòu)體當(dāng)中的成員變量往往比較復(fù)雜,通過引用傳遞可以避免結(jié)構(gòu)體的整體拷貝,可以節(jié)省時(shí)間和內(nèi)存。
不僅如此,我們還可以通過函數(shù)返回引用:
1
|
P& return_ref(P& a); |
返回引用的目的和傳遞引用參數(shù)的目的是一樣的,為了節(jié)省時(shí)間和內(nèi)存。
如果函數(shù)返回的不是引用,而是結(jié)構(gòu)體的值的話,調(diào)用代碼可能是這樣的:
1
|
P m = return_ref(a); |
return_ref
這個(gè)函數(shù)的返回結(jié)果會(huì)先賦值到一個(gè)臨時(shí)的位置,然后再復(fù)制給m。這和我們傳遞結(jié)構(gòu)體參數(shù)的開銷是一樣的,如果我們返回的類型是引用,那么則可以節(jié)省掉這個(gè)開銷。
但是,這里有一個(gè)坑。
我們通過函數(shù)返回的引用,不能是函數(shù)終止時(shí)就不存在的內(nèi)存單元,也就是不能是臨時(shí)變量。
比如下面這個(gè)例子就是不行的:
1
2
3
4
|
P& return_ref(P& a) { P cur = a; return cur; } |
我們?cè)诤瘮?shù)當(dāng)中將傳入的結(jié)構(gòu)體a
拷貝了一份,對(duì)這個(gè)拷貝體進(jìn)行了返回。這樣的代碼從邏輯上看是沒有問題的,但問題是我們創(chuàng)建的cur
是一個(gè)臨時(shí)變量,當(dāng)函數(shù)返回的時(shí)候就會(huì)被銷毀,不再存在,于是就會(huì)導(dǎo)致一些未知的錯(cuò)誤。
所以如果要使用函數(shù)返回引用的話,一定要返回外部傳入的引用或者全局變量的引用,而不能在函數(shù)內(nèi)部臨時(shí)創(chuàng)建。
除此之外,返回引用還有另外一個(gè)坑點(diǎn),我們來看代碼:
1
2
3
|
P a,b; return_ref(a) = b; |
這樣的語法是被允許的,因?yàn)?code>return_ref函數(shù)返回的是一個(gè)引用,我們當(dāng)然可以對(duì)一個(gè)引用的值進(jìn)行修改。有的情況下這一樣會(huì)產(chǎn)生問題,如果你不想要這樣的情況被允許,也有辦法,我們可以使用const
關(guān)鍵字,
將返回的結(jié)果限制成不可修改:
1
|
const P& return_ref(P& a); |
到此這篇關(guān)于C++引用和結(jié)構(gòu)體介紹的文章就介紹到這了,更多相關(guān)C++引用和結(jié)構(gòu)體內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!