gethostbyname

SYNOPSIS

#include <netdb.h>

struct hostent *gethostbyname(const char *name);

Data Structure

http://www.cnblogs.com/LubinLew/p/POSIX-DataStructure.html#struct_hostent 

Description

gethostbyname 是不可重入函数,在多线程编程时需要注意, linux中有可重入版本 gethostbyname_r,

POSIX标准里面使用getaddrinfo和getnameinfo来替换gethostbyname系列函数了,这些函数已经已经被废弃了。 

Parameter

参数 name 既可以是一个主机名(例如"www.163.com"),也可以是IPv4地址(点分十进制形式,例如"111.202.60.48")或者IPv6地址(冒号分隔16进制地址.例如"2000::1:2345:6789:abcd").

如果参数是IPv4或者IPv6地址,那么函数不会执行查询操作,返回的结构体中 h_name 就是该参数的拷贝, h_addr_list[0]就是该参数对应的的整型网络字节(相当于inet_pton(AF_INET*, name, dst)).

 If name doesn’t end in a dot and the environment variable HOSTALIASES is set, the alias file pointed to by HOSTALIASES will first be searched for name (see hostname(7) for the file format).

The current domain and its parents are searched unless name ends in a dot.

 

Example

#include <stdio.h>
#include <netdb.h>
#include <arpa/inet.h>

int main(void)
{
    int i = 0;
    char str[32] = {0};
     struct hostent* phost = NULL;
 
    phost = gethostbyname("www.163.com");
    if (NULL == phost)
    {
        return -1;    
    }
    
    printf("---Offical name:\n\t%s\n", phost->h_name);

    printf("---Alias name:\n");    
    for (i = 0;  phost->h_aliases[i]; i++)
    {
        printf("\t%s\n", phost->h_aliases[i]);
    }

    printf("---Address list:\n");
    for (i = 0; phost->h_addr_list[i]; i++)
    {
        printf("\t%s\n", inet_ntop(phost->h_addrtype,  phost->h_addr_list[i], str, sizeof(str)-1));
    }

    return 0;
} 

运行结果

---Offical name:
	163.xdwscache.glb0.lxdns.com
---Alias name:
	www.163.com
	www.163.com.lxdns.com
---Address list:
	111.202.60.48
	111.202.60.47

 

posted @ 2015-06-09 14:03  LubinLew  阅读(7883)  评论(0编辑  收藏  举报