大端模式和小端模式【YC】

小端:较高的有效字节存放在较高的的存储器地址,较低的有效字节存放在较低的存储器地址。
大端:较高的有效字节存放在较低的存储器地址,较低的有效字节存放在较高的存储器地址。
下面这段代码可以用来测试一下你的编译器是大端模式还是小端模式:
short int x;
char x0,x1;
x=0x1122;
x0=((char*)&x)[0]; //低地址单元
x1=((char*)&x)[1]; //高地址单元
若x0=0x11,则是大端; 若x0=0x22,则是小端......
上面的程序还可以看出,数据寻址时,用的是低位字节的地址

1、通常在TCP/IP协议栈所说的网络序(Network Order)就是遵循Big-Endian规则;
     网络与主机字节转换函数:htons ntohs htonl ntohl (s 就是short l是long h是host n是network)
2、不同的CPU上运行不同的操作系统,字节序也是不同的
     有的处理器系统采用了小端方式进行数据存放,如Intel的奔腾。
     有的处理器系统采用了大端方式进行数据存放,如IBM半导体和Freescale的PowerPC处理器。
3、栈操作:
     大端模式:低地址存放高位,每入栈一个数,栈顶地址减1,每出栈一个数,栈顶地址加1,
                    即堆栈区是由内存的高地址向低地址。
     小端模式:低地址存放低位,每入栈一个数,栈顶地址加1,每出栈一个数,栈顶地址减1,
                    即堆栈区是由内存的低地址向高地址。

你可能感兴趣的:(IBM,单元测试,网络协议)