C语言之返回局部变量
文章目录
概述
题主在编写函数之时发现返回一个指针变量之时屡屡出现错误,后来发现其实是对内存的理解不足导致的,如今我将函数的返回细细梳理,以飨读者。
一、弄清楚几个概念
1.C语言的内存管理
动态区域
这里分为栈区(stack)与堆区(heap):
栈区:函数的参数值,局部变量,例如在函数之中直接定义一个int型或者指针类型,那么在程序(函数)执行之时会为他们在栈区分配空间,但是程序(函数)结束之后就会被回收,也就是说这个时候访问他们会是无效的。
堆区:需要用动态内存分配函数malloc等函数从堆中申请一块内存空间,而与栈不同的是,堆的空间释放不是自动的,申请之后需要用free函数释放。
静态区域
这里分为bss段、data段、text段:
bss段:未初始化的全局变量、静态变量将其用零(或空指针)初始化
data段:已经初始化的全局变量、静态变量、常量数据
text段:存放cpu可执行的机器命令,由于程序经常被使用,防止其被修改,代码区通常是只读的。
2.局部变量的存储类型
auto(自动类型):C语言规定,如果局部变量不作存储类型说明,则就为auto型,例如下面等价:
int a,b;
auto int a,b;
而这样的局部变量存储在动态区域的栈区之中
static(静态类型):生命周期一直到程序结束,存储在静态区域的data段之中,也就是说,程序运行过程之中不会被回收,直到结束才会被回收。
register(寄存器类型):由于与本篇关系不大,不做赘述。
二、实验说明局部变量的返回
1.环境
这里我用的是VS code和gcc编译环境。
2.返回局部变量的值(地址)
基本数据类型(int、long、double、char):
int fun()
{
int a=1,b=2,c;
c=a+b;
return c;
}
在主函数之中运行,可以得到正确结果,说明在函数之中直接返回局部变量的值是可以,这里大家基本都清楚就不在赘述。
然后我们再看看返回一个地址:
int *fun()
{
int a