matlab 大端读数据,计算机在内存中存储数据时使用了大端(bigendian)、小

本文详细解释了计算机内存中数据存储的大端模式和小端模式,并通过实例演示了这两种模式下整数变量的内存布局差异。此外,还提供了一个简单的程序来检测当前CPU采用的是哪种模式。
部署运行你感兴趣的模型镜像

转载于https://blog.csdn.net/One_L_Star/article/details/81739729 有没有想过当定义一个变量的时候,这个变量在内存中是如何存放的呢?这就涉及到数据格式中的大端模式(Big-endian)和小端模式(Little-endian) 大端模式(Big-endian):高位字节存放在内存的低端地址,低位字节存放在内存的高端地址 小端模式(Little-endian):低位字节存放在内存的高端地址,高位字节存放在内存的低端地址 eg1:int a = 0x12345678,a在内存中是如何保存的? int型变量需要4个字节保存数据,a是4个字节的变量 把 a 分为 0x12,0x34,0x56,0x78 4个部分,分别保存到4个字节中 内存中,每个字节都有一个编号,这个编号就是内存的地址,所以没每个字节都有一个地址 a 需要占据4个字节,就会占据4个地址,这4个地址也是从低地址变化到高地址 若 a 变量中高字节(0x12)保存在低地址,则是大端模式 若 a 变量中低字节(0x78)保存在低地址,则是小端模式 如图,假设起始地址为0x4000 大端模式(Big-endian): 内存地址 0x4000 0x4001 0x4002 0x4003 存放内容 0x12 0x34 0x56 0x78 小端模式(Little-endian): 内存地址 0x4000 0x4001 0x4002 0x4003 存放内容 0x78 0x56 0x34 0x12 eg2:使用程序判断CPU是大端还是小端 #include int main() { union w { int a; char b; } c; c.a = 0x12345678; printf("%x\n",c.b); } 打印结果为:78 我使用的是Linux系统编写的程序,由此可以看出此CPU为小端模式 分析:联合体所有成员占用同一段内存,修改一个成员会影响所有成员,给联合体的 a 赋值,但 a 和 b 的类型不同,从而轻松地获得了CPU对内存采用Little-endian还是Big-endian模式读写。

发表于 2020-04-21 00:55:50

回复(0)

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值