释放可变函数中的所有参数 - c

时间:2013-02-07 07:40:58

标签: c variadic-functions

我有一个创建函数的任务,它接收可变数量的参数并释放所有参数,任何类型的参数。 我尝试使用可变参数函数来做,但问题是我不知道参数的类型。

有任何建议吗?

1 个答案:

答案 0 :(得分:2)

将每个指针视为void *;将其传递给free()

void free_anything(void *arg1, ...)
{
    va_list args;
    void *vp;
    free(arg1);
    va_start(args, arg1);
    while ((vp = va_arg(args, void *)) != 0)
        free(vp);
    va_end(args);
}

示例电话:

free_anything(p1, p2, p3, p4, (void *)0);

另一种设计传递了要作为第一个参数释放的参数数量的计数:

free_everything(4, p1, p2, p3, p4);

替代功能的实施留作练习......


请注意,带有计数器(free_everything())的设计可能更好;您可以编写一个函数来清除函数中的多个分配:

void memory_intensive(int size)
{
    int *p1 = malloc(size * sizeof(*p1));
    char *p2 = malloc(size * 32);
    struct wotnot *p3 = malloc(sizeof(*p3));
    struct onemore *p4 = malloc(size * sizeof(*p4));
    struct later *p5 = 0;
    struct muchlater *p6 = 0;

    if (some_condition(p1, p3, size))
    {
        p5 = malloc(size * sizeof(*p5));
        ...
    }
    if (another_condition(p2, p4, size))
    {
        p6 = malloc(size * sizeof(*p6));
        ...
    }

    free_everything(6, p1, p2, p3, p4, p5, p6);
}

这将释放单个函数调用中的所有已分配内存,无论是分配了p5还是p6(或者是否有任何其他分配失败)。然而,这正在扩大极限。但是,在这样的设计中,至关重要的是不要停留在第一个空指针...以防以后列表中有非空指针。