例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