C/C++——联合体的内存模型和应用

  1. 联合体和结构体的区别

    联合体和结构体都是可以存储不同类型数据的构造数据类型,结构体和共用体的区别在于:结构体的各个成员会占用不同的内存,互相之间没有影响;而共用体的所有成员占用同一段内存,修改一个成员会影响其余所有成员。

    结构体占用的内存大于等于所有成员占用的内存的总和(成员之间可能会存在缝隙,位域知识),共用体占用的内存等于最长的成员占用的内存。共用体使用了内存覆盖技术,同一时刻只能保存一个成员的值,如果对新的成员赋值,就会把原来成员的值覆盖掉。

  2. 大端模式和小端模式

    大端模式(Big-endian)是指将数据的低位(比如 1234 中的 34 就是低位)放在内存的高地址上,而数据的高位(比如 1234 中的 12 就是高位)放在内存的低地址上。

    小端模式(Little-endian)是指将数据的低位放在内存的低地址上,而数据的高位放在内存的高地址上。这种存储模式将地址的高低和数据的大小结合起来,高地址存放数值较大的部分,低地址存放数值较小的部分,这和我们的思维习惯是一致,比较容易理解。

    我们的 PC 机上使用的是 X86 架构的 CPU,它是小端模式;51 单片机是大端模式;很多 ARM、DSP 也是小端模式(部分 ARM 处理器还可以由硬件来选择是大端模式还是小端模式)

  3. 联合体的内存模型
    定义一个联合体,这个联合体所占的空间是4字节,

    union data{
        int n;
        char ch;
        short m;
    };
    

    他们在内存中的模型是
    在这里插入图片描述
    假设这是小端存储模式,上面是低地址,下面是高地址,成员 n、ch、m 在内存中“对齐”到一头,对 ch 赋值修改的是前一个字节,对 m 赋值修改的是前两个字节,对 n 赋值修改的是全部字节。也就是说,ch、m 会影响到 n 的一部分数据,而 n 会影响到 ch、m 的全部数据。

  4. 联合体的应用
    联合体的应用之一就在于判断cpu是大端模式还是小端模式。

    #include <stdio.h>
    int main()
    {
        union
        {
            int n;
            char ch;
        } data;
    
        data.n = 0x00000001;  //只用了一个字节的空间;
        if(data.ch == 1)
        {
        	printf("%d\n",data.ch);
            printf("小端模式\n");
        }
        else
        {
       		printf("%d\n",data.ch);
            printf("大端模式\n");
        }
        return 0;
    }
    

    运行结果
    在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值