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

2022-06-17 04:12:14 字數 2314 閱讀 8228

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

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

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

左值引數是可被引用的資料物件,例如,變數、陣列元素、結構成員、引用和被解除引用的指標都是左值,非左值包括字面常量和包含多項式的表示式。定義乙個函式?1

2345

6789

1011

1213

1415

1617

1819

2021

2223

2425

2627

2829

30double refcube(constdouble& ra)

doubleside = 3.0;

double* pd = &side;

double& rd = side;

longedge = 5l;

doublelens[4]=;

doublec1 = refcube(side);// ra 是side

doublec2 = refcube(lens[2]);// ra是lens[2]

doublec3 = refcube(rd);// ra 是 rd

doublec4 = refcube(*pd);// ra 是*pd

doublec5 = refcube(edge);// ra 是臨時變數

doublec6 = refcube(7.0);// ra 是臨時變數

doublec7 = refcube(side+10.0);// ra 是臨時變數

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

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

2345

6789

1011

1213

void swapr(int& a,int& b)

在早期的c++較寬鬆的規則下,執行下面的操作將發生什麼?

long a = 3,b = 5;

swapr(a,b);

這裡的型別不匹配,因此編譯器將建立兩個臨時的int變數,將他們初始化為3和5,然後交換臨時變數的內容,而a和b保持不變

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

(ps:如果函式呼叫的引數不是左值或與相應的const引用引數的型別不匹配,則c++將建立型別正確的匿名變數,將函式呼叫的引數的值傳遞給該匿名變數,並讓引數來引用該變數)

應盡可能使用const

使用cosnt可以避免無意總修改資料的程式設計錯誤

使用const使函式能夠處理const和非const實參,否則將只能接受非const資料

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

使用子查詢時應當注意的

在乙個查詢中 update a set a.scts b.v1,a.ycyl b.v2,a.ycsl b.v3 from kfdbsyy a,select f wellnumber,count as v1,sum f fule as v2,sum f totalliquid f fule as v3...

c 引數傳遞之引用引數

每乙個想要做到模組化程式設計的碼農都不可避免的乙個問題是引數傳遞 如果您在這裡覺得有疑問,誒,我不想做模組化呢,以筆者經驗這個你大可不必揪心,因為你的老師或者老闆會讓你做到的 以c語言為例,主調函式傳參給被調函式的情況中,87 的情況都是要改變引數的值。這時候有兩種方法做到這個,第一傳指標,一般情況...

C 引用 3 使用引用或者指標傳遞引數

c 中,在下面的這幾種情況下,一般使用引用來傳遞引數。1 在被調函式中修改主調函式中的區域性變數 例如,下面例子中函式fun 可以修改main 中的區域性變數x.include void fun int x int main void printstudetails student stu clas...