内存地址中的16进制最小单位是1bit,1Byte?

本文探讨了在小端模式下,内存地址中的16进制单位实际上是1Byte而不是1bit。通过GDB调试,展示了内存地址从0x601038到0x601039的变化,揭示了内存地址的最小单位。同时解释了16进制每两位对应一个字节的原因,并提供了在线转换工具。

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

在研究 union的时候遇到一个题目,是关于大小端的问题,从而牵扯出了探索内存地址的问题

#include <stdio.h>

static union {
    int i;
    char a[2];
} abc;

int main() {
    abc.a[0] = 10; // 低
    abc.a[1] = 1; //高
    printf("%d\n", abc.i); //266  10a
    return 0;
}

一般机器为小端,所以当小端的时候这里的结果为266.

为什么那?

首先这里是union共用体,所以大小为 sizeof(int).
比如地址有4个编号,1,2,3,4 分别表示低->高, 由于这里是小端,所以1->10(a),2->1(1),3->0(0),4->0(0) 括号内的为16进制

整体则为: 0x0000010a

自己也就是在 0x0000010a 上面迷糊,为什么不是0x1a 那?

这里如果要是知道16进制每两位为一个字节, 就很简单了.比如说上面4个编号,正好对应那4字节空间,每个字节空间依次对应0x0000010a 中的2位,也就是第一个字节对应0a,第二个字节对应01,依次类推.

探索

为什么内存地址中的16进制最小单位是1bit,1Byte?

通过gdb调试可以看到以下结果:

 0x601038  00000000 00000010 00000001 00001010
 0x601039  00000000 00000000 00000010 00
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值