关于字节序请参考http://blog.csdn.net/androidbluetooth/article/details/6429009
ntohl()
简述:#include <winsock.h>, u_long PASCAL FAR ntohl( u_long netlong);netlong:一个以网络[字节顺序表达的32位数。
#include <winsock.h> u_short PASCAL FAR ntohs( u_short netshort);netshort:一个以网络字节顺序表达的16位数。
#include <winsock.h> u_long PASCAL FAR htonl( u_long hostlong);hostlong:主机字节顺序表达的32位数。
#include <winsock.h> u_short PASCAL FAR htons( u_short hostshort);hostshort:主机字节顺序表达的16位数。
返回值:htons()返回一个网络字节顺序的值。
转载一篇好文章,便于您更好地理解与认识这几个函数。来源:http://my.oschina.net/alphajay/blog/4277
ntohs =net to host short int 16位 htons=host to net short int 16位 ntohl =net to host long int 32位 htonl=host to net long int 32位
#include u_short PASCAL FAR ntohs( u_short netshort);netshort:一个以网络字节顺序表达的16位数。
#include u_short PASCAL FAR htons( u_short hostshort);hostshort:主机字节顺序表达的16位数。
ina.sin_addr.s_addr = inet_addr(“132.241.5.10″);注意,inet_addr()返回的地址已经是网络字节格式,所以你无需再调用 函数htonl()。
printf(“%s”,inet_ntoa(ina.sin_addr));它将输出IP地址。需要注意的是inet_ntoa()将结构体in-addr作为一 个参数,不是长整形。同样需要注意的是它返回的是一个指向一个字符的 指针。它是一个由inet_ntoa()控制的静态的固定的指针,所以每次调用 inet_ntoa(),它就将覆盖上次调用时所得的IP地址。例如:
char *a1, *a2; a1 = inet_ntoa(ina1.sin_addr); /* 这是198.92.129.1 */ a2 = inet_ntoa(ina2.sin_addr); /* 这是132.241.5.10 */ printf(“address 1: %s “,a1); printf(“address 2: %s “,a2);输出如下:
#include char FAR* PASCAL FAR inet_ntoa( struct in_addr in); in:一个表示Internet主机地址的结构。注释:
include #include #include #include #include int main(int aargc, char* argv[]) { struct in_addr addr1,addr2; ulong 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 “, inet_ntoa(addr1), inet_ntoa(addr2)); //注意这一句的运行结果 printf(“%s “, inet_ntoa(addr1)); printf(“%s “, inet_ntoa(addr2)); return 0; } 实际运行结果如下: 192.168.0.74 : 192.168.0.74 //从这里可以看出,printf里的inet_ntoa只运行了一次。 192.168.0.74 211.100.21.179inet_ntoa返回一个char *,而这个char *的空间是在inet_ntoa里面静态分配的,所以inet_ntoa后面的调用会覆盖上一次的调用。第一句printf的结果只能说明在printf里面的可变参数的求值是从右到左的,仅此而已。