htonl\htons\ntonl\ntons

htonl()

简述:
将主机的无符号长整形数转换成网络 字节顺序
#include <arpa/inet.h>
uint32_t htonl(uint32_t hostlong);
hostlong:主机 字节顺序表达的32位数。
注释:
函数将一个32位数从主机 字节顺序转换成网络字节顺序。
返回值:
htonl()返回一个网络 字节顺序的值。
网际协议在处理这些多字节整数时,使用 大端 字节序
主机本身就使用 大端 字节序时,这些 函数通常被定义为空宏。
MSDN原文:
This function converts a u_longfrom host to TCP/IP network byte order, which is big-endian.
u_long htonl(u_long hostlong );Parameters
  • hostlong
  • [in] 32-bit number in host byte order.
Return Values
This function returns the value in TCP/IP network byte order.
Remarks
This function takes a 32-bit number in host byte order and returns a 32-bit number in the network byte order used in TCP/IP networks.
htonl,其实是host to network, l 的意思是返回类型是long

htons()

简述:
将主机的无符号短整形数转换成网络 字节顺序
#include <winsock.h>
u_short PASCAL FAR htons( u_short hostshort);
hostshort:主机字节顺序表达的16位数。
注释:
本函数将一个16位数从主机字节顺序转换成网络字节顺序。
返回值:
htons()返回一个网络字节顺序的值。
简单地说,htons()就是将一个数的高低位互换
(如:12 34 --> 34 12)

ntohl()

简述

含义

将一个无符号长整形数从网络 字节顺序转换为主机字节顺序。

头文件

#include <arpa/inet.h>

函数形式

uint32_t ntohl(uint32_t netlong);
netlong:一个以网络[ 字节顺序表达的32位数。

编辑本段注释

本函数将一个32位数由网络字节顺序转换为主机字节顺序。

编辑本段返回值

ntohl()返回一个以主机 字节顺序表达的数。

ntohs()

简述

将一个无符号短整形数从网络 字节顺序转换为主机字节顺序。
#include <netinet/in.h>
uint16_t ntohs(uint16_t netshort);
netshort:一个以网络 字节顺序表达的16位数。

注释

本函数将一个16位数由网络 字节顺序转换为主机字节顺序。

返回值

ntohs()返回一个以主机 字节顺序表达的数。

参见

编辑本段ntohs, ntohl,htons,htonl的比较

htons()

本函数将一个16位数从主机 字节顺序转换成网络字节顺序。
返回值:
htons()返回一个网络 字节顺序的值。
这2个函数提供了主机 字节顺序与网络字节顺序的转换
比如网络字节 为 00 01
u_short a如果直接对应的话 a=0100; 为什么呢?因为主机是从高字节到低字节的,所以应该转化后a=ntohs(0001); 这样 a=0001;

htonl()

htonl()表示将32位的主机 字节顺序转化为32位的网络字节顺序  htons()表示将16位的主机字节顺序转化为16位的网络字节顺序(ip地址是32位的 端口号是16位的 )
将IP地址转换成 长整型:首先,假设你已经有了一个sockaddr_in 结构体ina,你有一个IP地址"132.241.5.10" 要储存在其中,你就要用到函数inet_addr(),将IP地址从点数格式转换成无符号长整型。使用方法如下:ina.s in_addr.s_addr = inet_addr("132.241.5.10");
注意,inet_addr()返回的地址已经是网络字节格式,所以你无需再调用函数 htonl()
我们现在发现上面的代码片断不是十分完整的,因为它没有错误检查。显而易见,当inet_addr()发生错误时返回-1。记住这些二进制数字?(无符号数)-1仅仅和IP地址255.255.255.255相符合!但这可是 广播地址!所以,记住要先进行错误检查。
怎样将一个 in_addr 结构体输出成点数格式?你要用到函数 inet_ntoa()("ntoa"的含义是"network to ascii"),就像这样:printf("%s",inet_ntoa(ina.s in_addr));它将输出IP地址。需要注意的是inet_ntoa()将 结构体in_addr作为一个参数,不是长整形。同样需要注意的是它返回的是一个指向一个字符的 指针。它是一个由inet_ntoa()控制的静态的固定的 指针,所以每次调用 inet_ntoa(),它就将覆盖上次调用时所得的IP地址。例如:
char *a1, *a2;
.
.
a1 = inet_ntoa(ina1.s in_addr);
a2 = inet_ntoa(ina2.s in_addr);
printf("address 1: %s ",a1);
printf("address 2: %s ",a2);
输出如下:
address 1: 132.241.5.10
address 2: 132.241.5.10
假如你需要保存这个IP地址,使用strcopy()函数来指向你自己的字符 指针

inet_ntoa()

简述:
网络地址转换成“.”点隔的字符串格式。
#include <winsock.h>
char FAR* PASCAL FAR inet_ntoa( struct  in_addr in);
in:一个表示Internet 主机地址的结构。
注释:
本函数将一个用in参数所表示的Internet地址结构转换成以“.” 间隔的诸如“a.b.c.d”的字符串形式。请注意inet_ntoa()返回的字符串存放在WINDOWS 套接口实现所分配的内存中。 应用程序不应假设该内存是如何分配的。在同一个线程的下一个WINDOWS 套接口调用前,数据将保证是有效。
返回值:
若无错误发生,inet_ntoa()返回一个字符指针。否则的话,返回NVLL。其中的数据应在下一个WINDOWS 套接口调用前复制出来。
参见:  inet_addr().
测试代码如下
#pragma comment (lib,"Ws2_32.lib")
//noths.obj : error LNK2001: unresolved external ymbol _inet_addr@4
#include <winsock.h>
#include < iostream.h>
#include <stdio.h>
int main(int aargc, char* argv[])
{
struct  in_addr addr1,addr2;
unsigned long l1,l2;
l1= inet_addr("192.168.0.74");
l2 = inet_addr("211.100.21.179");
memcpy(&addr1, &l1, 4);
memcpy(&addr2, &l2, 4);
printf("%s : %s \n", inet_ntoa(addr1), inet_ntoa(addr2)); //注意这一句的运行结果
printf("%s \n", inet_ntoa(addr1));
printf("%s \n", inet_ntoa(addr2));
return 0;
}
实际运行结果如下:
192.168.0.74 : 192.168.0.74 //从这里可以看出,printf里的inet_ntoa只运行了一次。
192.168.0.74
211.100.21.179
inet_ntoa返回一个char *,而这个char *的空间是在inet_ntoa里面静态分配的,所以inet_ntoa后面的调用会覆盖上一次的调用。第一句printf的结果只能说明在printf里面的可变参数的求值是从右到左的,仅此而已。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值