1.非静态局部变量在函数调用结束后释放,不能返回其地址
2.动态分配内存可跨越函数栈区限制,手动释放
3.静态变量为保证后续调用仍可接着之前值使用,函数调用结束后不释放
#include <stdio.h>
#include <stdlib.h>
//①返回局部变量地址:warning C4172: 返回局部变量或临时变量的地址
int *add1(int a, int b){
int sum = a + b;
return ∑
}
//②返回动态内存分配地址(指针)
int *add2(int a, int b){
int *sum = new int;
*sum = a + b;
return sum;
}
//③返回静态变量地址:静态变量所占空间不会被其他占用
int *add3(int a, int b){
static int sum = a + b;
return ∑
}
int main(){
int *sum;
//---------①----------
//sum = add1(3, 5);//单次调用不会出错,但一旦后续再有函数,会取代原有局部变量的栈区,地址无效
/*/---------②----------
sum = add2(3, 5);
delete sum;//没有申请内存则不得调用,否则会终止;需要return调用地址后再释放内存,故delete不能写在函数中即return前
*/
//---------③----------
sum = add3(3, 5);
printf("*sum=%d", *sum);
return 0;
}