您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關C++中const引用、臨時變量、引用參數的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
C++引用—臨時變量、引用參數和const引用
如果實參與引用參數不匹配,C++將生成臨時變量。如果引用參數是const,則編譯器在下面兩種情況下生成臨時變量:
實參類型是正確的,但不是左值
實參類型不正確,但可以轉換為正確的類型
左值參數是可被引用的數據對象,例如,變量、數組元素、結構成員、引用和被解除引用的指針都是左值,非左值包括字面常量和包含多項式的表達式。定義一個函數
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指向它。這些臨時變量只在函數調用期間存在,伺候編譯器便可以任意將其刪除
那么為什么對于常量引用,這種行為是可行的,其他情況下卻不行呢?
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引用、臨時變量、引用參數的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。