inet_addr()

更新时间:2023-11-03 15:43

inet_addr()的功能是将一个点分十进制的IP转换成一个长整数型数(u_long类型)

基本介绍

原型:in_addr_t inet_addr(const char *cp);

参数:字符串,一个点分十进制的IP地址

返回值:

如果正确执行将返回一个无符号长整数型数。如果传入的字符串不是一个合法的IP地址,将返回INADDR_NONE。

头文件:

Winsock2.h (windows)

arpa/inet.h (Linux)

英文原意

The Windows Sockets inet_addr function converts a string containing an (Ipv4) Internet Protocol dotted address into a proper address for the IN_ADDR structure.

unsigned long inet_addr(const char FAR *cp );

Parameters

cp

Return Values

If no error occurs, inet_addr returns an unsigned long value containing a suitable binary representation of the Internet address given. If the string in the cp inet_addr returns the value INADDR_NONE.

Remarks The inet_addr function interprets the character string specified by the cpinet_addr function, inet_addr returns zero.

基本注释

本函数解释cp参数中的字符串,这个字符串用Internet的“.”间隔格式表示一个数字的Internet地址。返回值可用作Internet地址。所有Internet地址以网络字节顺序返回(字节从左到右排列)。

Internet地址用“.”间隔的地址可有下列几种表达方式:

a.b.c.d,a.b.c,a.b,a

当四个部分都有定值时,每个都解释成一个字节数据,从左到右组成Internet四字节地址。请注意,当一个Internet地址在Intel机器上表示成一个32位整型数时,则上述的字节为“d.c.b.a”。这是因为Intel处理器的字节是从右向左排列的。

请注意:只有Berkeley支持下述表达法,Internet其余各处均不支持。考虑到与软件的兼容性,应按规定进行使用。

对一个三部分地址,最后一部分解释成16位数据并作为网络地址的最右两个字节。这样,三部分地址便很容易表示B组网络地址,如“128.net.host”.

对一个两部分地址,最后一部分解释成24位数据并作为网络地址的最右三个字节,这样,两部分地址便很容易表示C组网络地址,如“net.host”。

对仅有一个部分的地址,则将它的值直接存入网络地址不作任何字节的重组。

返回值:

若无错误发生,inet_addr()返回一个无符号长整型数,其中以适当字节顺序存放Internet地址。如果传入的字符串不是一个合法的Internet地址,如“a.b.c.d”地址中任一项超过255,那么inet_addr()返回INADDR_NONE。在IP只有一部分时(即没有 ”.“ 时),IP的字符串如果只由数字组成,inet_addr()不检查数字是否大于255。

基本要求

操作系统:Windows 2000 Professional 或更高版本

头文件:Winsock2.h

链接库:Ws2_32.lib

参见:

inet_ntoa().

例如: *.sin_addr.s_addr=htonl(inaddr_any)是什么意思?

答: *.sin_addr.s_addr=htonl(inaddr_any) 是SOCKET编程中用到的.

*是任意定义的一个sockaddr_in型的结构体对象 sin_addr是他的一个属性,用于定义IP地址,是struct in_addr型的,s_addr为结构体in_addr的对象,简单说就是三个结构体嵌套包装的一个包.

inaddr_any一般为内核指定的,大多数系统取0,表示任意的IP地址.

htonl()简单说是一个把本机IP转化为网络协议中规定的格式的函数.也就是所谓的大端模式或小端模式

编程举例

免责声明
隐私政策
用户协议
目录 22
0{{catalogNumber[index]}}. {{item.title}}
{{item.title}}