Linux编程 sockaddr_in sockaddr in_addr详解。

时间:2021-12-04 04:41:24



struct hostent {  
  char *h_name; /* 主机的官方域名 */
   char **h_aliases; /* 一个以NULL结尾的主机别名数组 */
   int h_addrtype; /* 返回的地址类型,在Internet环境下为AF-INET */
   int h_length; /* 地址的字节长度 */
   char **h_addr_list; /* 一个以0结尾的数组,包含该主机的所有地址*/
};


#define h_addr h_addr_list[0] /*在h-addr-list中的第一个地址*/  

===============================================================================================


struct sockaddr {  
unsigned short sa_family; // address family, AF_xxx
char sa_data[14]; // 14 bytes of protocol address
};
sockaddr 是通用的socket地址,具体到Internet   socket,用下面的结构,二者可以进行类型转换  

sa_family是地址家族,一般都是“AF_xxx”的形式。通常大多用的是都是AF_INET,代表TCP/IP协议族

sa_data是14字节协议地址。

数据结构用做bind、connect、recvfrom、sendto等函数的参数,指明地址信息。但一般编程中并不直接针对此数据结构操作,而是使用另一个与sockaddr等价的数据结构


struct   sockaddr_in   {  
short int sin_family; // Address family
unsigned short int sin_port; // Port number
struct in_addr sin_addr; /* Internet address */
unsigned char sin_zero[8]; /* Same size as struct sockaddr */
};



struct   in_addr   {  
union {
struct { u_char s_b1,s_b2,s_b3,s_b4; } S_un_b;
struct { u_short s_w1,s_w2; } S_un_w;
u_long S_addr;
} S_un;

#define s_addr S_un.S_addr

 struct   in_addr就是32位IP地址

sin_family指代协议族,在socket编程中只能是AF_INET

  sin_port存储端口号(使用网络字节顺序)   sin_addr存储IP地址,使用in_addr这个数据结构   sin_zero是为了让sockaddr与sockaddr_in两个数据结构保持大小相同而保留的空字节。   s_addr按照网络字节顺序存储IP地址   sockaddr_in和sockaddr是并列的结构,指向sockaddr_in的结构体的指针也可以指向   sockaddr的结构体,并代替它。也就是说,你可以使用sockaddr_in建立你所需要的信息,   然后用进行类型转换就可以了bzero((char*)&mysock,sizeof(mysock));//初始化   sockaddr_in mysock;   bzero((char*)&mysock,sizeof(mysock));   mysock.sa_family=AF_INET;   mysock.sin_port=htons(1234);//1234是端口号   mysock.sin_addr.s_addr= inet_addr("192.168.0.1");

  inet_addr()是将一个点分制的IP地址(如192.168.0.1)转换为上述结构中需要的32位IP地址(0xC0A80001)。