IP地址: 32位无符号整数.
表示形式:
1-- 点分十进制形式 : 123.123.123.123.
2-- 二进制形式:
存放类型:
结构体 或者 32位无符号整型.
struct in_addr //结构体1
{
union {
struct { u_char s_b1,s_b2,s_b3,s_b4; } S_un_b; //结构体2 单位为:u_char(8bit)
struct { u_short s_w1,s_w2; } S_un_w;//结构体3 单位为 u_short (16bit)
u_long S_addr; //无符号长整型 单位为u_long (32bit)
}S_un; //联合体
}; //这是网络字节序. 那主机字节序呢??
字节序 主机字节序和网络字节序, (排序不同, 排序的最小单位是 : byte 还是 bit?) 问题1:
转换的 函数: 关键字 Host TO Net Long Short
htonl()
ntohl()
htons()
ntohs()
这四个都是 操作 二进制形式的 IP ,那二进制ip 如何转换 到 点分十进制ip? 问题2.
inet_ntoa() ulong 到 char*, 二进制 填充到 点分十进制格式的字符数组,
inet_addr() char* 到 ulong 点分十进制到二进制
低位和高位?低四位, 低八位,低十六位. ,,最通用的说法 应该是 低八,高八, 已字节为单位.
大端和小端?
以数据类型为整体, 字节 为单位, 两种排序 (内存地址的高低,也就是地址指针的大小.). 是字节为单位么? 还是和 cpu寻址也有关系?(字长为单位)
比如,以一组10人为整体, 1人为单位, 两种排序, (身高)
但是,例子中 排列的单位是
例如,16bit宽的数0x1234在Little-endian模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:
内存地址 | 0x4000 | 0x4001 |
存放内容 | 0x34 | 0x12 |
而在Big-endian模式CPU内存中的存放方式则为:
内存地址 | 0x4000 | 0x4001 |
存放内容 | 0x12 | 0x34 |
32bit宽的数0x12345678在Little-endian模式CPU内存中的存放方式(假设从地址0x4000开始存放)为:
内存地址 | 0x4000 | 0x4001 | 0x4002 | 0x4003 |
存放内容 | 0x78 | 0x56 | 0x34 | 0x12 |
而在Big-endian模式CPU内存中的存放方式则为:
内存地址 | 0x4000 | 0x4001 | 0x4002 | 0x4003 |
存放内容 | 0x12 | 0x34 | 0x56 | 0x78 |
联合体union的存放顺序是所有成员都从低地址开始存放。
既然,IP地址都要转换。那么,网络字节序和主机字节序,排序的单位,应该是 以固定大小为单位的,而不是以单个数据为整体的 。
大小不固定,会造成很大的网络资源的浪费。
具体的,我自己在回复里头扯了一大堆。。。是为 拉面。。。 老板,来一碗拉面,这两天肠胃不好,拉的细一点。