所谓的大端模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;ios
所谓的小端模式,是指数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址中。(大部分的操做系统都是小端,而通信协议是大端)spa
为何会有大小端模式之分呢?这是由于在计算机系统中,咱们是以字节为单位的,每一个地址单元都对应着一个字节,一个字节为8bit。可是在C语言中除了8bit的char以外,还有16bit的short型,32bit的long型(要看具体的编译器),另外,对于位数大于8位的处理器,例如16位或者32位的处理器,因为寄存器宽度大于一个字节,那么必然存在着一个若是将多个字节安排的问题。所以就致使了大端存储模式和小端存储模式。例如一个16bit的short型x,在内存中的地址为0x0010,x的值为0x1122,那么0x11为高字节,0x22为低字节。对于大端模式,就将0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中。小端模式,恰好相反。咱们经常使用的X86结构是小端模式,而KEIL C51则为大端模式。不少的ARM,DSP都为小端模式。有些ARM处理器还能够由硬件来选择是大端模式仍是小端模式。操作系统
内存地址 | 小端模式存放内容 | 大端模式存放内容 |
0x4000 | 0x34 | 0x12 |
0x4001 | 0x12 | 0x34 |
32bit宽的数0x12345678在Little-endian模式以及Big-endian模式)CPU内存中的存放方式(假设从地址0x4000开始存放)为:code
内存地址 | 小端模式存放内容 | 大端模式存放内容 |
0x4000 | 0x78 | 0x12 |
0x4001 | 0x56 | 0x34 |
0x4002 | 0x34 | 0x56 |
0x4003 | 0x12 | 0x78 |
能够看出来小端模式,读取内存就能够获得相应数字,无需调整结构,而大端须要调整结构,可是大端能够最早读到正负符号,快速得知该数字是正数仍是负数。blog
验证一下~:内存
#include <iostream> using namespace std; void IsBigEndian() { int a = 0x1234; char b = *(char *)&a; //经过将int强制类型转换成char单字节,经过判断起始存储位置。即等于 取b等于a的低地址部分 if( b == 0x12) { cout<<"big endian"<<endl; return; } cout<<"small endian"<<endl; return; } int main() { IsBigEndian(); }