#include <stdio.h>
#include <string.h>
#include <stdlib.h>
char* f(void) {
char *x;
x = malloc(sizeof(char) * 4);
strcpy(x, "abc");
return(x);
}
int main(void) {
char *a;
a = f();
printf("%s", a);
free(a);
return(0);
}
是变量吗? x 在函数中必须被释放?如果是这样,当我需要退货时,这怎么可能呢?
是否必须释放函数中的变量x?
是的(有点,见我后来的评论)。每次打电话 malloc 需要稍后的电话 free。否则,你有泄漏。但请记住;你不是“自由的” x“,你正在释放x所指的记忆。
你什么时候回来 x 一份副本 值 (地址) x 制作并返回给来电者。 x 声明具有自动存储持续时间。它所引用的内存必须被释放。
如果是这样,当我需要返回时,这怎么可能。
您的设计将责任放在呼叫者身上以释放内存。你已经完成了这个。当然,使用此方法需要您记录该函数,以便代码的用户知道他们正在接收动态分配的内存地址。
更好的方法(IMO)是将缓冲区作为输入参数。现在很清楚谁负责管理这个内存(即调用者)。也许我甚至不想动态分配它。有了这个设计,这是我的选择。
void f(char *buf, size_t buf_size) {
strncpy(buf, "abc", buf_size - 1);
buf[buf_size-1] = '\0';
}
另外,您应该始终检查返回值 malloc。它可能会失败,在这种情况下将返回空指针。也, sizeof(char) 保证是 1 按标准,所以你可以删除那一点,然后说 malloc(n)。
是的,应该由呼叫者释放。如那个 free 在你的主要。
你什么时候回来 x 在功能 f,地址的副本将传递回调用者。来电者可以打电话 free 在那个地址上。
是的,你需要自由,但是当你这样做时它已经被释放了 free(a); 在 main (以来 a 被赋予相等的 x 在线 a = f();)。
x 退出函数后会被销毁。的价值 x 是指向动态分配的对象的地址。退出函数后,该对象仍然存在。
要释放动态对象,您必须传递值 x 这是由...返回的 f 功能 free 功能。
你打电话时 malloc 它分配内存并返回该内存块的初始地址。
在您的情况下,您将此地址返回给被调用者,现在被调用者main负责解除分配。
解除内存块所需的唯一内容是初始地址,AFIK负责分配/释放内存它使用相当复杂的算法,但程序只需要跟踪初始内存地址。这个地址可以像任何其他整数值一样存储或移动,因为在32位系统中,它只是一个int值。
你的代码工作得很好,你获释了 a 这是f的字符串malloced。