数据存储——大小端问题介绍

本文详细解析了大端和小端字节序的概念,通过具体实例展示了不同字节序下数据的存储方式,并说明了Intel x86和ARM平台普遍采用的小端字节序特点。

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

在实际软件调试时,会做数据类型的转换,比如强制类型转换,将int ---> short , unsigned --> signed ,以及不同的平台做开发时,

比如linux ,Window, ARM,不同平台的数据存储机制是不一样的。

关于大小端的基本概念如下:

        大端:高位存在低地址,低位存在高地址;
        小端:高位存在高地址,低位存在低地址;(intel的x86,ARM普遍都是属于小端)

        举个例子,从内存地址0x0000开始有以下数据
        0x0000    0x12
        0x0001    0x34
        0x0002    0xab
        0x0003    0xcd

        如果我们去读取一个地址为0x0000的四个字节变量:
                若字节序为big-endian,  则读出结果为0x1234abcd
                若字节序位little-endian,则读出结果为0xcdab3412

        如果我们将0x1234abcd写入到以0x0000开始的内存中,则结果为:
                         big-endian      little-endian
        0x0000          0x12                  0xcd
        0x0001          0x23                  0xab
        0x0002          0xab                  0x34
        0x0003          0xcd                  0x12
        
        Intelx86系列以及ARM系列CPU都是little-endian的字节序.
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值