被调用函数里动态分配的内存要不要手动释放
20
我想手动释放来着,但是指针是在被调用函数里声明的,在调用函数里释放不了。
我的被调用函数返回的就是这个指针,我也不能在被调用函数里释放。
我的被调用函数返回的就是这个指针,我也不能在被调用函数里释放。
你指的“动态分配”是系统自动分配内存,如 char c[100];
还是手动分配的,如 char *p = (char *)malloc(100);
如果是第一种方式,则不需要手动释放。
第二种方式,释放时需要制定内存区域的指针,如free(p)。如果你在调用函数里手动分配了内存,那么需要将内存指针返回,然后再释放。
如
1
2
3
4
5
6
7
8
9
10
|
char
* proc1()
{
char
*p = (
char
*)
malloc
(100);
retrun p;
}
void
proc2()
{
char
*p = proc1();
//调用 proc1
free
(p);
}
|
其他
都看糊涂了,你的意思是如下代码吗?
int* Func2(void)
{
int *p = new int(0);
return p;
}
void Func(void)
{
int *p = Func();
delete p;
p = NULL;
}
如果是如上代码,不可能释放不了,堆是属于整个进程的,在堆中申请的内存在任何地方都可以释放.
int* Func2(void)
{
int *p = new int(0);
return p;
}
void Func(void)
{
int *p = Func();
delete p;
p = NULL;
}
如果是如上代码,不可能释放不了,堆是属于整个进程的,在堆中申请的内存在任何地方都可以释放.
我看的是C 被调用函数里的变量不是本地变量吗,它在函数结束时是不是自动删除的。而不用手动释放。
首先,被调用函数里的变量是在线程栈中分配的,在离开作用域里自动回收这是没错的.但这里的自动变量是指针P,而不是指针所指向的内存,这里是有区别的,指针P所占用的内存当然会自动回收,但指针所指的内存是由malloc分配的,这是在进程的默认堆里分配的,必须用free回收(不过就算没调用free程序结束时也会由操作系统回收). 从你发出的代码来看是完全没有问题的,不知道你说的不能释放是什么意思.