(转)测试CPU是大端Big endian 还是小端Little Endian的C代码
原文:http://www.51bigfool.com/big-endian-or-ittle-endian.html
看周立功的《C程序设计高级教程》做的笔记。这本书还不错,已经帮我搞清楚了几个以前比较迷糊的概念。
一、关于大端Big Endian和小端Little Endian的概念
对于单一的字节(a byte),大部分处理器以相同的顺序处理位元(bit),因此单字节的存放方法和传输方式一般相同。对于多字节的数据,如int,long,有大端和小端之分。
最低有效位(Least Significant Bit, LSB)表示数的最低位。
最高有效位(Most Significant Bit, MSB)表示数的最高位。对于带符号数来说,最高位就是符号位。比如int 类型的“5”在32位机器上的表示为:0000 0000 0000 0000 0000 0000 0000 0101,其中,最左边的一位0是符号位,即MSB = 0; 最右边的”1“是数的最低有效位,即LSB = 1。
注意:MSB(全大写)有时也指the Most Significant Byte,最高有效字节,指多字节序列中具有最大权重的字节。
大端模式:即将数据的最高有效字节MSB存放在低地址单元中,将最低有效字节LSB存放在高地址单元中。那么数据的地址就是MSB所在的地址。如图所示:
小端模式:即将数据的最低有效字节LSB存放在低地址单元中,将最高有效字节MSB存放在高地址单元中。那么数据的地址就是LSB所在的地址。如图所示:
二大小端测试代码原理:
如果将任何类型的对象指针强制转换为指向任何char类型的指针,其结果就是”指向对象的第一个字节“的指针。无论系统的字节次序结构如何,这里所认定的第一个字节就是地址最低的那个字节。代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
#include<stdio.h> int main() { unsigned int uiTest; unsigned char *pucTmp = NULL; uiTest = 0x12345678; pucTmp = (unsigned char *)&uiTest; //指向&uiTest的第一个字节 if (*pucTmp == 0x78) { printf ( "This is Little Endian\n" ); } else { printf ( "This is Big Endian\n" ); } return 0; } |