C 为什么要将整个'hints'变量设置为0?
我正在阅读Beej的《网络编程指南》,在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
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
指针(视情况而定)