大端存储/小端存储

 

【理解】不管是大端法还是小端法存储,计算机在内存中存放数据的顺序都是从低地址到高地址,所不同的是首先取低字节的数据存放在低地址还是取高字节数据存放在低地址。

  • 若首先取高字节的数据存放在低地址,则是大端法;   
  •  若首先取低字节的数据存放在低地址,则是小端法。






便于记忆:

【一个高字节的数据宁愿屈身存储在 低地址中,可见它的 ”大气端庄“——>大端】偷笑

(大端)高尾端:高地址 存放 尾巴数据

(小端)高尾端:低地址 存放 尾巴数据


对应例题如下:



解释:

 unsigned int a= 0x1234; 其中32位中,int是4字节, 大端存储 ,补齐16进制表示为: 0x00 00 12 34  
  unsigned char b=*(unsigned char *)&a; char占一个字节,所以上述int a变量的最低地址存储的是  十六进制表示中最左边的1字节, 为0x00.  

若处理器为小端 (低地址存储低位) 模式,则b的值为0x34。


### 大端存储小端存储的定义及区别 大端存储(Big-Endian)和小端存储(Little-Endian)是计算机中用于表示多字节数据(如整数、浮点数等)在内存中的两种不同方式[^1]。具体来说: #### 1. **大端存储(Big-Endian)** 大端存储是一种将数据的高字节存储在低地址,低字节存储在高地址的方式。换句话说,在内存中,数据的最高有效字节(Most Significant Byte, MSB)被放置在最低的内存地址上[^2]。例如,对于一个32位整数 `0x12345678`,其在大端存储下的内存布局为: ``` 地址: 0x00 0x01 0x02 0x03 值: 0x12 0x34 0x56 0x78 ``` #### 2. **小端存储(Little-Endian)** 小端存储则是将数据的低字节存储在低地址,高字节存储在高地址的方式。也就是说,数据的最低有效字节(Least Significant Byte, LSB)被放置在最低的内存地址上[^3]。同样以 `0x12345678` 为例,其在小端存储下的内存布局为: ``` 地址: 0x00 0x01 0x02 0x03 值: 0x78 0x56 0x34 0x12 ``` #### 3. **两者的区别** - **字节顺序**:大端存储按照从高到低的字节顺序排列,而小端存储则相反,按照从低到高的字节顺序排列。 - **硬件实现**:大端存储通常出现在网络协议栈和某些嵌入式系统中,如 Motorola 和 SPARC 架构处理器;小端存储则广泛应用于 x86 和 x86_64 架构的处理器[^4]。 - **可读性**:对于人类阅读十六进制数据时,大端存储更直观,因为其顺序与书写习惯一致。然而,小端存储在处理低位优先的计算时可能更高效。 #### 示例代码 以下是一个简单的 Python 程序,展示如何判断当前系统的字节序并演示两种存储方式的区别: ```python import sys # 判断当前系统的字节序 print(f"系统字节序: {'端' if sys.byteorder == 'big' else '小端'}") # 示例数据 data = 0x12345678 # 小端存储 little_endian_bytes = data.to_bytes(4, byteorder='little') print(f"小端存储: {list(little_endian_bytes)}") # 大端存储 big_endian_bytes = data.to_bytes(4, byteorder='big') print(f"大端存储: {list(big_endian_bytes)}") ``` 运行上述代码后,可以观察到不同字节序下数据的内存表示差异。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值