當C++使用引用傳遞參數時,應當注意的問題


如果實參與引用參數不匹配,C++將生成臨時變量。如果引用參數是const,則編譯器在下面兩種情況下生成臨時變量:

實參類型是正確的,但不是左值

實參類型不正確,但可以轉換為正確的類型

左值參數是可被引用的數據對象,例如,變量、數組元素、結構成員、引用和被解除引用的指針都是左值,非左值包括字面常量和包含多項式的表達式。定義一個函數

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
Double refcube( const double & ra)
 
{
      Returnra*ra*ra;
}
 
 
double side = 3.0;
 
double * pd = &side;
 
double & rd = side;
 
long edge = 5L;
 
double lens[4]={2.3,3.4,4.5,6.7};
 
double c1 = refcube(side); // ra 是side
 
double c2 = refcube(lens[2]); // ra是lens[2]
 
double c3 = refcube(rd);  // ra 是 rd
 
double c4 = refcube(*pd); // ra 是*pd
 
double c5 = refcube(edge); // ra 是臨時變量
 
double c6 = refcube(7.0); // ra 是臨時變量
 
double c7 = refcube(side+10.0); // ra 是臨時變量

參數side lens[2] rd 和*pd都是有名稱的、double類型的數據對象,因此可以為其創建引用,而不需要臨時變量。但是edge雖然是變量,類型卻不正確,double引用不能指向long。另一方面,參數7.0和side+10.0的類型都正確,但沒有名稱,在這些情況下,編譯器都將生成一個臨時匿名變量,並讓ra指向它。這些臨時變量只在函數調用期間存在,伺候編譯器便可以任意將其刪除

那么為什么對於常量引用,這種行為是可行的,其他情況下卻不行呢?

?
1
2
3
4
5
6
7
8
9
10
11
12
13
Void swapr( int & a, int & b)
 
{
 
      Inttemp;
 
      Temp=a;
 
      A= b;
 
      B= temp;
 
}

 

在早期的C++較寬松的規則下,執行下面的操作將發生什么?

Long a = 3,b = 5;

Swapr(a,b);

這里的類型不匹配,因此編譯器將創建兩個臨時的int變量,將他們初始化為3和5,然后交換臨時變量的內容,而a和b保持不變

簡而言之,如果接受引用參數的函數的意圖是修改作為參數傳遞的變量,則創建臨時變量將阻止這種意圖的實現,解決方法是,禁止創建臨時變量,下載的C++標准正是正陽做的、

現在來看refcube()函數,該函數的目的只是使用傳遞的值,而不是修改他們,因此臨時變量不會造成任何不利的影響。反而會使函數在可處理的參數種類方面更通用。因此,如果聲明將引用指定為const,C++將在必要時生成臨時變量、實際上,對於形參為const引用的C++函數,如果實參不匹配,則其行為類似於按值傳遞,為確保原始數據不被修改,將使用臨時變量來存儲值、

(PS:如果函數調用的參數不是左值或與相應的const引用參數的類型不匹配,則C++將創建類型正確的匿名變量,將函數調用的參數的值傳遞給該匿名變量,並讓參數來引用該變量)

應盡可能使用const

使用cosnt可以避免無意總修改數據的編程錯誤

使用const使函數能夠處理const和非const實參,否則將只能接受非const數據

使用const引用使函數能夠正確生成並使用臨時變量

以上這篇C++ const引用、臨時變量 引用參數詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM