原创 Little endian和Big endian的区别

2010-12-22 15:48 2464 10 10 分类: MCU/ 嵌入式

许多嵌入式系统程序员对Little endian和Big endian模式的概念模糊不清,其实little endian和big endian是多字节寻址的微处理器中,两种数据书写和存储顺序的排列方式(格式)。


1、Little endian:多字节数据中,书写时字节从右向左排列(MSB…LSB),存储时高位地址存放高位数据(MSB)。Little endian是最常用的模式,其书写格式(例如“反汇编”出来的源代码)与传统的十进制和二进制数据的书写格式相同,现在主流微处理器,包括8051系列单片机、Intel 8x86 CPU等都采用这种模式。


2、Big endian:多字节数据中,书写时字节从左向右排列(LSB…MSB),存储时高位地址存放低位数据(LSB)。Big endian模式仅Motorolra(现为Freescale)等少数几个公司的CPU采用。


TI公司的DSP通过配置可以选用Little endian和Big endian两种模式,但通常都配置为Little endian模式。


假设从地址0x0000开始保存有数据0xEF23(或0EF23H)。


●Little endian模式:书写表达:0xEF23, 在内存中的存放顺序是0x0000-0x23, 0x0001-0xEF。


●Big  endian模式:书写表达:0x23EF,在内存中的存放顺序是0x0000-0xEF, 0x0001-0x23。


  需要特别说明的是, 以上假设系统是每个内存单元以8位即一个字节为单位的。


  简单的说, Little endian把低字节存放在内存的低位;而Big endian将低字节存放在内存的高位。

文章评论0条评论)

登录后参与讨论
我要评论
0
10
关闭 站长推荐上一条 /2 下一条