Linux下正确使用getifaddrs()函数避免内存泄露

工作中使用valgrind检测内存泄露时,发现getifaddrs()很容易导致内存泄露,下面是正确的代码:

//get local ip of network card
//gcc -g get_addr.c -o get_addr
//

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <ifaddrs.h>

int main(int argc, char* argv[]){
    struct ifaddrs *ifc, *ifc1;
    char ip[64] = {};
    char nm[64] = {};

    if(0 != getifaddrs(&ifc)) return -1;
    ifc1 = ifc;

    printf("iface\tIP address\tNetmask\n");
    for(; NULL != ifc; ifc = (*ifc).ifa_next){
        printf("%s", (*ifc).ifa_name);
        if(NULL != (*ifc).ifa_addr) {
            inet_ntop(AF_INET, &(((struct sockaddr_in*)((*ifc).ifa_addr))->sin_addr), ip, 64);
            printf("\t%s", ip);
        }else{
            printf("\t\t");
        }
        if(NULL != (*ifc).ifa_netmask){
            inet_ntop(AF_INET, &(((struct sockaddr_in*)((*ifc).ifa_netmask))->sin_addr), nm, 64);
            printf("\t%s", nm);
        }else{
            printf("\t\t");
        }
        printf("\n");
    }

    //freeifaddrs(ifc);
    freeifaddrs(ifc1);
    return 0;
}
编译方法:

gcc -g get_addr.c -o get_addr

运行和检测如下:


但是如果将末尾的ifc1更改为ifc,就会造成内存泄露, 真正的原因是, ifc不是真正的链表, 仅是伪链表.参见下面的参考文献[1].


参考文献

[1].http://xinzhiwen198941-163-com.iteye.com/blog/994704

[2].http://blog.csdn.net/bailyzheng/article/details/7489656 

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值