大小端模式

本文详细解释了大端和小端两种字节序存储模式的基本概念,并通过实例对比了它们的区别。同时,提供了测试编译器字节序类型的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自http://baike.baidu.com/link?url=aFsfHbN6lmUWvubZrYQRseRguo4MHAOzqt-zm-WeG_DccdbMdGcUnev0UGAKBnL03Oo_vHNeRd9unxjhYclfHK
大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;这和我们的阅读习惯一致。
例子:
0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000
在大端模式下,前32位应该这样读: e6 84 6c 4e ( 假设int占4个字节)

小端模式,是指数据的高字节保存在内存的高地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低。
例子:
0000430: e684 6c4e 0100 1800 53ef 0100 0100 0000
在小端模式下,前32位应该这样读: 4e 6c 84 e6( 假设int占4个字节)

大小端模式

为什么会有大小端模式之分呢?这是因为在计算机系统中,我们是以字节为单位的,每个地址单元都对应着一个字节,一个字节为 8bit。

编辑器模式

下面这段代码可以用来测试一下你的编译器是大端模式还是小端模式:
1
2
3
4
5
short int x;
char x0,x1;
x=0x1122;
x0=((char*)&x)[0]; //低地址单元
x1=((char*)&x)[1]; //高地址单元
若x0=0x11,则是大端; 若x0=0x22,则是小端......
上面的程序还可以看出,数据寻址时,用的是低位字节的地址。
以下是原创:
#include <iostream>
using namespace std;
void main()
{
int x;
char x0,x1,x2,x3;
x=0x31323334;    //ASCII码31对应数字1 32对应数字2 33对应数字3 34对应数字4
x0=(int)((char*)&x)[0]; //低地址单元
x1=((char*)&x)[1]; //高地址单元
x2=(int)((char*)&x)[2]; //低地址单元
x3=((char*)&x)[3]; //高地址单元
cout<<x0<<endl;//4
cout<<x1<<endl;//3
cout<<x2<<endl;//2
cout<<x3<<endl;//1
int xxj = 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值