- 5 -
现在,你可能想你已经知道它们了。你也可能想:“如果我想改变 char 的顺序要怎么办呢?”
但是你也许马上就想到,“用不着考虑的”。你也许 会想到:我的 68000 机器已经使用了网络
字节顺序,我没有必要去调用 htonl() 转换 IP 地址。你可能是对的,但是当你移植你的程序
到别的机器 上的时候,你的程序将失败。可移植性!这里是 Unix 世界!记住:在你 将数据
放到网络上的时候,确信它们是网络字节顺序的。
最后一点:为什么在数据结构 struct sockaddr_in 中, sin_addr 和 sin_port 需要转换为网络
字节顺序,而sin_family 需不需要呢? 答案是: sin_addr 和 sin_port 分别封装在包的 IP 和 U
DP 层。因此,它们必须要 是网络字节顺序。但是 sin_family 域只是被内核 (kernel) 使用来
决定在数 据结构中包含什么类型的地址,所以它必须是本机字节顺序。同时, sin_family 没
有发送到网络上,它们可以是本机字节顺序。
--------------------------------------------------------------------------------
IP 地址和如何处理它们
现在我们很幸运,因为我们有很多的函数来方便地操作 IP 地址。没有 必要用手工计算它们,
也没有必要用"<<"操作来储存成长整字型。 首先,假设你已经有了一个sockaddr_in结构体in
a,你有一个IP地 址"132.241.5.10"要储存在其中,你就要用到函数inet_addr(),将IP地址从
点数格式转换成无符号长整型。使用方法如下:
001)%0&%020%3)
注意,返回的地址已经是网络字节格式,所以你无需再调用 函数。
我们现在发现上面的代码片断不是十分完整的,因为它没有错误检查。 显而易见,当inet_ad
dr()发生错误时返回-1。记住这些二进制数字?(无符 号数)-1仅仅和IP地址255.255.255.255
相符合!这可是广播地址!大错特 错!记住要先进行错误检查。
好了,现在你可以将IP地址转换成长整型了。有没有其相反的方法呢? 它可以将一个in_addr
结构体输出成点数格式?这样的话,你就要用到函数 inet_ntoa()("ntoa"的含义是"network to
ascii"),就像这样:
4)5) 0
它将输出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 */
4)%657) %
4)657)
输出如下:
%6%0&%020%3
6%0&%020%3
假如你需要保存这个8地址,使用4函数来指向你自己的字符 指针。
上面就是关于这个主题的介绍。稍后,你将学习将一个类 似"wintehouse.gov"的字符串转换
成它所对应的IP地址(查阅域名服务,稍 后)。
--------------------------------------------------------------------------------
socket()函数
我想我不能再不提这个了-下面我将讨论一下socket()系统调用。
下面是详细介绍:
#include <sys/types.h>
第 5 页 共 24 页