例1:
int f()
{
int i = 1;
return i;
}
int main
{
int r = f();
}
在例1的程序中,由於f()函數返回的是int類型,在函數結束時,要返回的值已經用於初始化函數的調用點的臨時量了(假設為temp,在main(調用者)中),函數執行完后,i確實是被銷毀了,但是temp還沒有被銷毀。int r= f()語句相當於執行:int r = temp;
例2:
int& f()
{
int i = 1;
return i;
}
int main
{
int& r = f();
}
如果返回引用類型,就沒有拷貝到一個臨時變量的過程,i被銷毀之后,引用也就不存在了,所以r得不到f()函數的返回值。
例3:
int* f()
{
int a = 1;
int *i = &a;
return i;
}
int main
{
int* r = f();
}
在例3中,i是一個int* 的局部變量,是一個地址變量,i指向的是局部變量a的內存空間,當函數結束時地址傳入到了temp中,i被銷毀,同時地址中指向的內存空間也被銷毀,所以當r = temp時,實際上指向的是一塊被銷毀的區域,所以不能這么調用。
轉自:https://blog.csdn.net/weixin_32737733/article/details/84843778
