您好,登錄后才能下訂單哦!
試看下面的代碼:
#include <iostream> using namespace std; void f(int &a) { cout << "f(" << a << ") is being called" << endl; } void g(const int &a) { cout << "g(" << a << ") is being called" << endl; } int main() { int a = 3, b = 4; f(a + b); //編譯錯(cuò)誤,把臨時(shí)變量作為非const的引用參數(shù)傳遞了 g(a + b); //OK,把臨時(shí)變量作為const&傳遞是允許的 }
上面的兩個(gè)調(diào)用之前,a+b的值會(huì)存在一個(gè)臨時(shí)變量中,當(dāng)把這個(gè)臨時(shí)變量傳給f時(shí),由于f的聲明中,參數(shù)是int&,不是常量引用,所以產(chǎn)生以下編譯錯(cuò)誤:
const_ref.cpp: In function `int main()': const_ref.cpp:14: error: invalid initialization of non-const reference of type ' int&' from a temporary of type 'int' const_ref.cpp:4: error: in passing argument 1 of `void f(int&)' 而在g(a+b)中,由于g定義的參數(shù)是const int&,編譯通過(guò)。 問(wèn)題是為什么臨時(shí)變量作為引用參數(shù)傳遞時(shí),必須是常量引用呢?很多人對(duì)此的解釋是臨時(shí)變量是常量,不允許賦值,改動(dòng),所以當(dāng)作為非常量引用傳遞時(shí),編譯器就會(huì)報(bào)錯(cuò)。這個(gè)解釋在關(guān)于理解臨時(shí)變量不能作為非const引用參數(shù)這個(gè)問(wèn)題上是可以的,但不夠準(zhǔn)確。事實(shí)上,臨時(shí)變量是可以被作為左值(LValue)并被賦值的,請(qǐng)看下面的代碼: #include <iostream> using namespace std; class CComplex { friend CComplex operator+(const CComplex &cp1, const CComplex &cp2); friend ostream& operator<<(ostream &os, const CComplex &cp); private: int x; public: CComplex(){} CComplex(int x1) { x = x1; } }; CComplex operator+(const CComplex &cp1, const CComplex &cp2) { CComplex cp3; cp3.x = cp1.x + cp2.x; return cp3; } ostream& operator<<(ostream &os, const CComplex &cp) { os << cp.x; return os; } int main() { CComplex a(2), b(3), c(4); cout << (a + b) << endl; cout << ((a + b) = c) << endl; //臨時(shí)對(duì)象作為左值 return 0; }
上面的程序編譯通過(guò),而且運(yùn)行結(jié)果是:
5
4
臨時(shí)變量確實(shí)被賦值,而且成功了。
所以,臨時(shí)變量不能作為非const引用參數(shù),不是因?yàn)樗浅A浚且驗(yàn)閏++編譯器的一個(gè)關(guān)于語(yǔ)義的限制。如果一個(gè)參數(shù)是以非const引用傳入,c++編譯器就有理由認(rèn)為程序員會(huì)在函數(shù)中修改這個(gè)值,并且這個(gè)被修改的引用在函數(shù)返回后要發(fā)揮作用。但如果你把一個(gè)臨時(shí)變量當(dāng)作非const引用參數(shù)傳進(jìn)來(lái),由于臨時(shí)變量的特殊性,程序員并不能操作臨時(shí)變量,而且臨時(shí)變量隨時(shí)可能被釋放掉,所以,一般說(shuō)來(lái),修改一個(gè)臨時(shí)變量是毫無(wú)意義的,據(jù)此,c++編譯器加入了臨時(shí)變量不能作為非const引用的這個(gè)語(yǔ)義限制,意在限制這個(gè)非常規(guī)用法的潛在錯(cuò)誤。
還不明白?OK,我們說(shuō)直白一點(diǎn),如果你把臨時(shí)變量作為非const引用參數(shù)傳遞,一方面,在函數(shù)申明中,使用非常量型的引用告訴編譯器你需要得到函數(shù)對(duì)某個(gè)對(duì)象的修改結(jié)果,可是你自己又不給變量起名字,直接丟棄了函數(shù)的修改結(jié)果,編譯器只能說(shuō):“大哥,你這是干啥呢,告訴我把結(jié)果給你,等我把結(jié)果給你了,你又直接給扔了,你這不是在玩我呢嗎?”所以編譯器一怒之下就不讓過(guò)了。這下大家明白了吧?
以上這篇c++中臨時(shí)變量不能作為非const的引用參數(shù)的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。