Union(联合体、共用体)

结构体和共用体的区别在于:结构体的各个成员会占用不同的内存,互相之间没有影响;而共用体的所有成员占用同一段内存,修改一个成员会影响其余所有成员。

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

经典示例:

c 复制代码
#include <stdio.h>
union un
{
	int i;
	char c[2];
};
int main()
{
	union un x;
	x.c[0]=10;
	x.c[1]=1;
	printf("\n%d",x.i);
	return 0;
 } 

在这个程序中,我们定义了一个联合(union)un,它包含一个整数i和一个字符数组c,这个字符数组有两个元素。

在main函数中,我们创建了一个un类型的变量x,并将x.c[0]赋值为10,x.c[1]赋值为1。然后我们打印x.i的值。

在这里,我们需要知道的是,联合中的所有成员共享同一块内存。也就是说,x.i和x.c共享同一块内存。

现在我们来看为什么输出结果是266。在这个程序中,我们假设使用的是小端存储方式。在小端存储中,对于一个多字节的数据,它的低位字节存储在低地址处,高位字节存储在高地址处。

因此,当我们将x.c[0]赋值为10(二进制表示为00001010),x.c[1]赋值为1(二进制表示为00000001)时,这两个字节被存储在内存中的顺序是0000000100001010。

这个二进制数转换成十进制是266。因此,当我们打印x.i的值时,输出结果为266。

相关推荐
艾莉丝努力练剑10 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
Cx330❀11 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
..过云雨12 小时前
01.【数据结构-C语言】数据结构概念&算法效率(时间复杂度和空间复杂度)
c语言·数据结构·笔记·学习
谱写秋天14 小时前
在STM32F103上进行FreeRTOS移植和配置(STM32CubeIDE)
c语言·stm32·单片机·freertos
我不是板神14 小时前
程序设计|C语言教学——C语言基础2:计算与控制语句
c语言
基于python的毕设14 小时前
C语言栈的实现
linux·c语言·ubuntu
promising-w18 小时前
【嵌入式C语言】六
c语言·开发语言
ankleless19 小时前
C语言(11)—— 数组(超绝详细总结)
c语言·零基础·数组·二维数组·自学·一维数组
草莓熊Lotso20 小时前
《吃透 C++ 类和对象(中):const 成员函数与取地址运算符重载解析》
c语言·开发语言·c++·笔记·其他
野生的编程萌新1 天前
从冒泡到快速排序:探索经典排序算法的奥秘(二)
c语言·开发语言·数据结构·c++·算法·排序算法