C++ const援用、暫時變量 援用參數詳解。本站提示廣大學習愛好者:(C++ const援用、暫時變量 援用參數詳解)文章只能為提供參考,不一定能成為您想要的結果。以下是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援用、暫時變量 援用參數詳解就是分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。