溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

c++中臨時(shí)變量不能作為非const的引用參數(shù)的方法

發(fā)布時(shí)間:2020-10-10 09:05:46 來(lái)源:腳本之家 閱讀:120 作者:jingxian 欄目:編程語(yǔ)言

試看下面的代碼:

#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è)參考,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI