C 为什么要将整个'hints'变量设置为0?

C 为什么要将整个'hints'变量设置为0?,c,sockets,C,Sockets,我正在阅读Beej的《网络编程指南》,在showip.c程序中,我看到了以下代码行: memset(&hints,0,sizeof-hints) 在对freenode上的##c通道进行讨论后,我推断,memset调用的原因可能是将hints.ai_flags的值设置为0(注意,程序运行良好,我删除了该行,并显式地将hints.ai_flags初始化为0)。如果这是真的,为什么他需要将整个结构设置为0 这是完整的来源: /* ** showip.c -- show IP addresses for

我正在阅读Beej的《网络编程指南》,在
showip.c
程序中,我看到了以下代码行:
memset(&hints,0,sizeof-hints)

在对freenode上的##c通道进行讨论后,我推断,
memset
调用的原因可能是将
hints.ai_flags
的值设置为
0
(注意,程序运行良好,我删除了该行,并显式地将
hints.ai_flags
初始化为0)。如果这是真的,为什么他需要将整个结构设置为
0

这是完整的来源:

/*
** showip.c -- show IP addresses for a host given on the command line
*/

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

int main(int argc, char *argv[])
{
    struct addrinfo hints, *res, *p;
    int status;
    char ipstr[INET6_ADDRSTRLEN];

    if (argc != 2) {
        fprintf(stderr,"usage: showip hostname\n");
        return 1;
    }

    memset(&hints, 0, sizeof hints);
    hints.ai_family = AF_UNSPEC; // AF_INET or AF_INET6 to force version
    hints.ai_socktype = SOCK_STREAM;

    if ((status = getaddrinfo(argv[1], NULL, &hints, &res)) != 0) {
        fprintf(stderr, "getaddrinfo: %s\n", gai_strerror(status));
        return 2;
    }

    printf("IP addresses for %s:\n\n", argv[1]);

    for(p = res;p != NULL; p = p->ai_next) {
        void *addr;
        char *ipver;

        // get the pointer to the address itself,
        // different fields in IPv4 and IPv6:
        if (p->ai_family == AF_INET) { // IPv4
            struct sockaddr_in *ipv4 = (struct sockaddr_in *)p->ai_addr;
            addr = &(ipv4->sin_addr);
            ipver = "IPv4";
        } else { // IPv6
            struct sockaddr_in6 *ipv6 = (struct sockaddr_in6 *)p->ai_addr;
            addr = &(ipv6->sin6_addr);
            ipver = "IPv6";
        }

        // convert the IP to a string and print it:
        inet_ntop(p->ai_family, addr, ipstr, sizeof ipstr);
        printf("  %s: %s\n", ipver, ipstr);
    }

    freeaddrinfo(res); // free the linked list

    return 0;
} 
/*
**c——显示命令行中给定主机的IP地址
*/
#包括
#包括
#包括
#包括
#包括
#包括
#包括
int main(int argc,char*argv[])
{
结构addrinfo提示,*res,*p;
智力状态;
char ipstr[INET6_ADDRSTRLEN];
如果(argc!=2){
fprintf(stderr,“用法:showip主机名\n”);
返回1;
}
memset(提示和提示,0,提示大小);
hits.ai_family=AF_unsec;//AF_INET或AF_INET6强制版本
hits.ai_socktype=SOCK_流;
if((status=getaddrinfo(argv[1],NULL,提示和res))!=0){
fprintf(标准,“getaddrinfo:%s\n”,gai_strerror(状态));
返回2;
}
printf(“%s的IP地址:\n\n”,argv[1]);
for(p=res;p!=NULL;p=p->ai_next){
无效*地址;
char*ipver;
//获取指向地址本身的指针,
//IPv4和IPv6中的不同字段:
如果(p->ai_family==AF_INET){//IPv4
*ipv4中的struct sockaddr_=(struct sockaddr_in*)p->ai_addr;
地址=&(ipv4->sin_addr);
ipver=“IPv4”;
}else{//IPv6
结构sockaddr_in6*ipv6=(结构sockaddr_in6*)p->ai_addr;
地址=&(ipv6->sin6_地址);
ipver=“IPv6”;
}
//将IP转换为字符串并打印:
inet_ntop(p->ai_系列、地址、ipstr、ipstr大小);
printf(“%s:%s\n”,ipver,ipstr);
}
freeaddrinfo(res);//释放链接列表
返回0;
} 

这是因为您只需要填充/使用初始化结构的一些字段,将
0
赋予其他字段可以防止读取未初始化的变量,有时
0
是这些变量的默认值

请注意,当我删除该行并显式初始化
hints.ai_flags
0


不一定,如果您在linux上,我建议使用来检测对未初始化变量的读取,因为这会导致未定义的行为,这种行为可能是什么都不会发生。

这是
getaddrinfo()
函数文档(您将
提示作为参数传递给
变量)所要求的。发件人:

hints
指向的结构中的所有其他字段必须包含
0
NULL
指针(视情况而定)