如果未释放hostent中的指针,gethostbyname_r会泄漏内存吗?

时间:2013-01-26 16:41:42

标签: c linux networking posix gethostbyaddr

gethostbyname_r的原型是:

int gethostbyname_r(const char *name,
    struct hostent *ret, char *buf, size_t buflen,
    struct hostent **result, int *h_errnop);

为了避免不可重入gethostbyname,我写了这些东西:

int host2addr(const char *host, struct in_addr *addr) {
    struct hostent he, *result;
    int herr, ret, bufsz = 512;
    char *buff = NULL;
    do {
        char *new_buff = (char *)realloc(buff, bufsz);
        if (new_buff == NULL) {
            free(buff);
            return ENOMEM;
        }   
        buff = new_buff;
        ret = gethostbyname_r(host, &he, buff, bufsz, &result, &herr);
        bufsz *= 2;
    } while (ret == ERANGE);

    if (ret == 0 && result != NULL) 
        *addr = *(struct in_addr *)he.h_addr;
    else if (result != &he) 
        ret = herr;
    free(buff);
    return ret;
}

这与GNU document中的示例以及gethostname的eglibc-2.15中的实现非常相似。

但我注意到,h_name中有h_aliasesh_addr_liststruct hostent

struct hostent {
   char  *h_name;            /* official name of host */
   char **h_aliases;         /* alias list */
   int    h_addrtype;        /* host address type */
   int    h_length;          /* length of address */
   char **h_addr_list;       /* list of addresses */
}

因此我想知道如果不释放那些指针引用的内容真的无关紧要。还有其他一些处理这些记忆的机制吗?

1 个答案:

答案 0 :(得分:5)

您应该打印出该结构中指针的值,以找出问题的答案。你会发现它们都指向你分配的缓冲区内的数据。

因此,只需要一个free即可释放所有内存。

这也意味着在完成使用或复制您感兴趣的任何数据之前,您不能释放该分配。您的代码过早释放。