在被调函数中开辟的内存内否在主调函数中使用?
4个回答
展开全部
分情况
1.普通变量 数组等
也就是最常见的函数局部变量,这样的变量占用的内存空间是不能在主调函数中使用的
比如 int func(){int a[1024];} 这里的a所占用空间,在函数结束后会被自动释放,无法继续使用
2.动态分配的内存
通过内存分配函数,在C中为malloc 在C++中为new/malloc, 申请的内存空间可以在主调函数中使用,直到被释放为止 free, delete/free
如 int * func(){int *t; t = malloc(4096); return t;} 这里申请的4K空间就可以返回给主调函数使用
3. 静态变量
理论上来说,虽然静态变量依赖于函数,但实际上它并不能算是函数中开辟出来的空间,这个界限比较模糊,我也不敢下定论
可以确定的是,静态变量可以给主调函数使用,只要管理得当,不会引起问题。
但是并不推荐这样做,因为会降低代码的可读性
int * func()
{
static int a[1024];
return a;
}
这样的方式也是可以的
1.普通变量 数组等
也就是最常见的函数局部变量,这样的变量占用的内存空间是不能在主调函数中使用的
比如 int func(){int a[1024];} 这里的a所占用空间,在函数结束后会被自动释放,无法继续使用
2.动态分配的内存
通过内存分配函数,在C中为malloc 在C++中为new/malloc, 申请的内存空间可以在主调函数中使用,直到被释放为止 free, delete/free
如 int * func(){int *t; t = malloc(4096); return t;} 这里申请的4K空间就可以返回给主调函数使用
3. 静态变量
理论上来说,虽然静态变量依赖于函数,但实际上它并不能算是函数中开辟出来的空间,这个界限比较模糊,我也不敢下定论
可以确定的是,静态变量可以给主调函数使用,只要管理得当,不会引起问题。
但是并不推荐这样做,因为会降低代码的可读性
int * func()
{
static int a[1024];
return a;
}
这样的方式也是可以的
展开全部
子函数开辟的内存会在子函数调用结束后自动回收,所以主函数不可以使用子函数开辟的内存。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
那要看是在堆中开辟的还是在堆栈中开辟的
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
可以。完全可以。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |