標籤:複製 res 一個 class 函數 參考型別 空間 strong ios
函數的傳回值用於初始化在調用函數是建立的臨時對象。
1、傳回值為非參考型別:
會將函數的傳回值複製給臨時對象。跟實參初始化形參的方式一樣。
2、傳回值為參考型別:
沒有複製傳回值,返回的是對象本身。返回引用時,在函數的參數中要有以引用方式或指標方式傳入的要返回的參數
不能返回局部對象的引用。(因為函數執行結束,將釋放分配給局部對象的儲存空間,對局部對象的引用就會指向不確定的記憶體)
int& abc(int a, int b, int c, int& result){ result = a + b + c; return result; } 這種形式也可改寫為: int& abc(int a, int b, int c, int *result){ *result = a + b + c; return *result; } 但是,如下的形式是不可以的: int& abc(int a, int b, int c){ return a + b + c; }
const string &manip(const string &s) { string ret =s; return ret; //wrong:returning reference to a local object }
3. 返回const 類型:
傳回值不能被修改。由於傳回值直接指向了一個生命期尚未結束的變數,因此,對於函數傳回值(或者稱為函數結果)本身的任何操作,都在實際上,是對那個變數的操作,這就是引入const類型的返回的意義。當使用了const關鍵字後,即意味著函數的傳回值不能立即得到修改!如下代碼,將無法編譯通過,這就是因為傳回值立即進行了++操作(相當於對變數z進行了++操作),而這對於該函數而言,是不允許的。如果去掉const,再行編譯,則可以獲得通過,並且列印形成z = 7的結果。
include <iostream> include <cstdlib> const int& abc(int a, int b, int c, int& result){ result = a + b + c; return result; } int main() { int a = 1; int b = 2; int c=3; int z; abc(a, b, c, z)++; //wrong: returning a const reference cout << "z= " << z << endl; SYSTEM("PAUSE"); return 0; }
1,什麼時候返回引用是正確的?而什麼時候返回const引用是正確的?
返回指向函數調用前就已經存在的對象的引用是正確的。當不希望返回的對象被修改時,返回const引用是正確的。
C++中傳回值