函數的返回值用於初始化在調用函數是創建的臨時對象。
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引用是正確的。
