c - 如何避免在每个 "return "之前调用 free()

标签 c free

我正面临 free() 的问题,而 free() 一直是 malloc()。有没有办法避免在下面的代码中多次写入 free(p)?

char *p = (char*) (malloc(100 * sizeof(char)));
if (A)
{
    free(p);
    p=NULL;
    return -1;
}
a++;
if (B)
{
    free(p);
    p=NULL;
    return -1;
}
b++;
if (C)
{
    free(p);
    p=NULL;
    return -1;
}
free(p);
p=NULL;
return 0; 

最佳答案

这可能不受欢迎,但您可以在函数末尾使用单个 goto 标签进行清理

    char *p = malloc(100);
    int ret = -1;
    if (A)
        goto cleanup;
    a++;
    if (B)
        goto cleanup;
    b++;
    if (C)
        goto cleanup;
    ret = 0; /* success */
cleanup:
    free(p);
    return ret; 

请注意,我对您的代码做了一些其他的小改动

  • malloc 的返回中删除了强制转换
  • 从您的分配计算中删除了 sizeof(char) 的使用。这保证是 1
  • 在函数末尾删除了 p 的 NULLing。它即将超出范围,因此它指向已释放的内存并不重要

关于c - 如何避免在每个 "return "之前调用 free(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15971755/

相关文章:

c - "error: expected unqualified-id before numeric constant"

C 内核 - 在 VM 上运行良好但在实际计算机上运行不正常?

c - 如何正确释放嵌套数据结构?

delphi - 动态创建/发布运行时表单的正确方法是什么?

c - free() 循环,正在触发断点,并且似乎没有释放元素

c - 在循环中分配和释放内存(C + MPI)

C:将年/月...转换为字符串(字符数组)?

c - 在 malloc() 之后使用 realloc() 来改变 unsigned char 数组的大小

c - 为什么网络服务器在发送响应之前应该清除套接字接收缓冲区?

c - 使用函数的免费双指针