【C语言】详解枚举与联合体

CSDN话题挑战赛第2期
参赛话题:

前言

这篇文章是对枚举与联合体这两个自定义类型的详细解释,阅读这篇文章,你可以使用枚举来代替define,你还可以学会考点联合体大小的计算以及用联合体来判断大小端存储。

一.枚举

1.枚举的定义

枚举在C/C++/c#中,是一个被命名的整型常数 的集合, 枚举在日常生活中很常见。

  • 例如:表示星期的SUNDAY, MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY,SATURDAY,就是一个枚举。

  • 枚举的结构和结构体类似

enum Day//星期
{
 Mon,
 Tues,
 Wed,
 Thur,
 Fri,
 Sat,
 Sun
};

enum Sex//性别
{
 MALE,
 FEMALE,
 SECRET
}
  • 以上定义的 enum Day , enum Sex , enum Color 都是枚举类型。
    {}中的内容是枚举类型的可能取值,也叫 枚举常量

  • 这些可能取值都是有值的,默认从0开始,一次递增1,比如enum Sex 中国 MALE,FEMALE 分别对应数字 0, 1 。

  • 在定义的时候也可以赋初值。

例如:

enum Color//颜色
{
 RED=1,
 GREEN=2,
 BLUE=4
};

2.枚举与define

有些读者可能会有些疑惑,不是可以用#define来定义常量么
为什么要使用枚举呢?

那是因为枚举具有很多优点:

  1. 增加代码的可读性和可维护性
  2. 和#define定义的标识符比较枚举有类型检查,更加严谨。
  3. 防止了命名污染(封装)
  4. 便于调试
  5. 使用方便,一次可以定义多个常量

3.枚举的使用

enum Color//颜色
{
 RED=1,
 GREEN=2,
 BLUE=4
};
enum Color clr = GREEN;
  • 只能拿枚举常量给枚举变量赋值 ,才不会出现类型的差异。
    不过编译器不是特别严谨的话不会报错。

  • 枚举中成员是常量 ,因此不能在枚举外赋值。

二.联合体

1.联合体的定义

在进行某些算法的C语言编程的时候,需要使几种不同类型的变量 存放到同一段内存单元中。也就是使用覆盖技术,几个变量互相覆盖。这种几个不同的变量共同占用 一段内存的结构。
在C语言中,被称作“共用体”类型结构,简称共用体,也叫联合体

比如:

//联合类型的声明
union Un
{
 char c;
 int i;
};
//联合变量的定义
union Un un;

2.联合体的特点

联合的成员是共用同一块内存空间的,这样一个联合变量的大小,至少是最大成员的大小 (因为联合至少得有能力保存最大的那个成员)。

union Un
{
 int i;
 char c;
};
union Un un;

下面输出的结果一样么?

printf("%d\n", &(un.i));
printf("%d\n", &(un.c));

结果如下:
在这里插入图片描述

  • 这个例子可以证明联合体中的成员确实是共用一块内存的。

  • 让我们回顾之前见过的一道面试题

判断当前计算机的大小端存储

  • 让我们尝试用联合体来解决它。
union Un
{
	int i;
	char c;
}u;
int main()
{
	u.i = 1;
	printf("%d", u.c);
	return 0;
}
  • i和c占用相同的空间,我们知道1的16进制是 00 00 00 01,char类型占用一个字节,因此若为小端存储,即低字节数存储在低地址处(01 00 00 00),就会输出1。

在这里插入图片描述

3.联合体大小的计算

  • 联合的大小至少是最大成员的大小。
  • 当最大成员大小不是最大对齐数的整数倍的时候,就要对齐到最大对齐数的整数倍。

比如:

union Un1
{
 char c[5];
 int i;
};
union Un2
{
 short c[7];
 int i;
};

下面输出的结果是什么?

printf("%d\n", sizeof(union Un1));
printf("%d\n", sizeof(union Un2));

char c[5]的大小是5,不是最大对齐数4的整数倍,因此结果为8
short c[7]的大小事14,不是最大对齐数4的整数倍,因此结果为16
在这里插入图片描述

最后

如果这篇文章对你有用的话,不妨点赞 收藏 关注。感谢支持!

  • 14
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

诺伯里-

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值