Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1527340
  • 博文数量: 329
  • 博客积分: 2773
  • 博客等级: 少校
  • 技术积分: 4219
  • 用 户 组: 普通用户
  • 注册时间: 2012-02-24 14:17
个人简介

淡定从容,宁静致远

文章分类

全部博文(329)

文章存档

2016年(4)

2015年(50)

2014年(68)

2013年(45)

2012年(162)

分类: LINUX

2012-06-01 09:28:23

ntohs()
  简述:
  将一个无符号短整形数从网络字节顺序转换为主机字节顺序。
  #include
  uint16_t ntohs(uint16_t netshort);
  netshort:一个以网络字节顺序表达的16位数。
  注释:
  本函数将一个16位数由网络字节顺序转换为主机字节顺序。
  返回值:
  ntohs()返回一个以主机字节顺序表达的数。
  参见:
  htonl(), htons(), ntohl().
ntohs, ntohl, htons,htonl的比较和详解
  本函数将一个16位数从主机字节顺序转换成网络字节顺序。
  返回值:
  htons()返回一个网络字节顺序的值。
  这2个函数提供了主机字节顺序与网络字节顺序的转换
  比如网络字节 为 00 01
  u_short a如果直接对应的话 a=0100; 为什么呢?因为主机是从高字节到低字节的,所以应该转化后a=ntohs(0001); 这样 a=0001;
  htonl()表示将32位的主机字节顺序转化为32位的网络字节顺序 htons()表示将16位的主机字节顺序转化为16位的网络字节顺序(ip地址是32位的端口号是16位的 )
  将IP地址转换成长整型:首先,假设你已经有了一个sockaddr_in结构体ina,你有一个IP地址"132.241.5.10" 要储存在其中,你就要用到函数inet_addr(),将IP地址从点数格式转换成无符号长整型。使用方法如下:ina.sin_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.sin_addr));它将输出IP地址。需要注意的是inet_ntoa()将结构体in_addr作为一个参数,不是长整形。同样需要注意的是它返回的是一个指向一个字符的指针。它是一个由inet_ntoa()控制的静态的固定的指针,所以每次调用 inet_ntoa(),它就将覆盖上次调用时所得的IP地址。例如:
  char *a1, *a2;
  .
  .
  a1 = inet_ntoa(ina1.sin_addr);
  a2 = inet_ntoa(ina2.sin_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 
  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
  #include
  #include
  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里面的可变参数的求值是从右到左的,仅此而已。
阅读(2010) | 评论(0) | 转发(0) |
0

上一篇:fd_set

下一篇:C字符串函数总汇解析

给主人留下些什么吧!~~