首页 > 其他分享 >C--联合和枚举

C--联合和枚举

时间:2024-09-30 21:19:31浏览次数:12  
标签:-- 联合体 char int 枚举 un 联合 union

欢迎各位看官!如果您觉得这篇文章对您有帮助的话
欢迎您分享给更多人哦 感谢大家的点赞收藏评论

感谢各位看官的支持!!!请添加图片描述

一:联合体

1.1: 联合体类型的声明

首先: 像结构体一样,联合体也是由⼀个或者多个成员构成,这些成员可以不同的类型。

但是编译器只为最大的成员分配足够的内存空间。联合体的特点是所有成员共用同一块内存空间。
所以联合体也叫:共用体。

因此:给联合体其中一个成员赋值,其他成员的值也跟着变化。

#include <stdio.h>
//联合类型的声明
union Un
{
 char c;
 int i;
};
int main()
{
 //联合变量的定义
 union Un un = {0};
 //计算连个变量的⼤⼩
 printf("%d\n", sizeof(un));4
 return 0;
 }

1.2 联合体的特点

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

//代码1
#include <stdio.h>
//联合类型的声明
union Un
{
 char c;
 int i;
};
int main()
{
 //联合变量的定义
 union Un un = {0};
 // 下⾯输出的结果是⼀样的吗?一样
 printf("%p\n", &(un.i));
 printf("%p\n", &(un.c));
 printf("%p\n", &un);
 return 0;
}

在这里插入图片描述
代码1输出的三个地址也一模一样,代码2的输出,我们发现将i的第4个字节的内容修改为55了。

//代码2
#include <stdio.h>
//联合类型的声明
union Un
{
 char c;
 int i;
};
int main()
{
 //联合变量的定义
 union Un un = {0};
 un.i = 0x11223344;
 un.c = 0x55;
 printf("%x\n", un.i);11223355
 return 0;
}

1.3:结构体浪费了很多(联合体省下的)空间

譬如
结构体:

struct S{
 char c;
  int i;
 };
 struct S s = {0}

联合体

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

在这里插入图片描述

1.4:联合体大小

**

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

#include <stdio.h>
	union Un1
	{
		char c[5];
		int i;
	};
	union Un2
	{
		short c[7];
		int i;
	};
	int main()
	{
		//下⾯输出的结果是什么?
		printf("%zd\n", sizeof(union Un1));//8
		printf("%zd\n", sizeof(union Un2));//16
		return 0;
	}

1.5:联合体节省空间的具体举例

使用联合体是可以节省空间的,举例:
比如,我们要搞⼀个活动,要上线⼀个礼品兑换单,礼品兑换单中有三种商品:图书、杯子、衬衫。
每⼀种商品都有:库存量、价格、商品类型和商品类型相关的其他信息。
图书: 书名、作者、页数
杯⼦: 设计
衬衫: 设计、可选、可选尺寸

struct gift_list
{
 //公共属性
 int stock_number;//库存量
 double price; //定价
 int item_type;//商品类型
 
 //特殊属性
 char title[20];//书名
 char author[20];//作者
 int num_pages;//⻚数
 
 char design[30];//设计
 int colors;//颜⾊
 int sizes;//尺⼨
};

上述的结构其实设计的很简单,用起来也方便,但是结构的设计中包含了所有礼品的各种属性,这样使得结构体的大小就会偏大,⽐较浪费内存。因为对于礼品兑换单中的商品来说,只有部分属性信息是常用的,比如:
商品是图书,就不需要design、colors、sizes。
所以我们就可以把公共属性单独写出来,剩余属于各种商品本⾝的属性使⽤联合体起来,这样就可以
介绍所需的内存空间,⼀定程度上节省了内存。

struct gift_list
{
 int stock_number;//库存量
 double price; //定价
 int item_type;//商品类型
 
 union 
 {
 struct
  {
 char title[20];//书名
 char author[20];//作者
 int num_pages;//⻚数
  }book;
 struct
 {
 char design[30];//设计
 }mug;
 struct
 {
 char design[30];//设计
 int colors;//颜⾊
 int sizes;//尺⼨
 }shirt;
 
 }item;
}S1;

1.6:大小端练习

int check_sys()
{
 union
 {
 int i;
 char c;
 }un;
 un.i = 1;
 return un.c;//返回1是⼩端,返回0是⼤端
}

二:枚举

2.1:枚举的声明

枚举顾名思义就是⼀⼀列举。

enum Day//星期
{
 Mon,
 Tues,逗号
 Wed,
 Thur,
 Fri,
 Sat,
 Sun  没有逗号
};默认值为0,1,2,3,4,5,6

2.2:枚举定义大小

enum Sex//性别
{
	Ab = 1,
	Bc,
	Cd
};
给Ab赋值=1,那接下来两个就按顺序来,
给BC赋值=5,那Ab不管你,还是=0,Cd顺序下来=6
或者给三个都赋值
enum Sex//性别
{
	Ab = 1,
	Bc =5 ,
	Cd =8 ,
};

2.3:枚举的优点

为什么使用 枚举?
我们可以使用 #define 定义常量,为什么非要使用枚举?
枚举的优点:

  1. 增加代码的可读性和可维护性
  2. 和#define定义的标识符⽐较枚举有类型检查,更加严谨。
  3. 便于调试,预处理阶段会删除 #define 定义的符号
  4. 使用方便,一次可以定义多个常量
  5. 枚举常量是遵循作⽤域规则的,枚举声明在函数内,只能在函数内使⽤

2.4:枚举的使用

使⽤枚举常量给枚举变量赋值

1 enum Color//颜⾊
2 {
3 RED=1,
4 GREEN=2,
5 BLUE=4
6 };
7
8 enum Color clr = GREEN;//使⽤枚举常量给枚举变量赋值
enum Color clr=3;
C++不行,c可以,因为左边是Color类型右边是int类型,不兼容

那是否可以拿整数给枚举变量赋值呢?

在C语言中是可以的,但是在C++是不行的,C++的类型检查比较严格。

上述就是联合和枚举的全部内容了
能看到这里相信您一定对小编的文章有了一定的认可,有什么问题欢迎各位大佬指出
欢迎各位大佬评论区留言修正

您的支持就是我最大的动力请添加图片描述
在这里插入图片描述

标签:--,联合体,char,int,枚举,un,联合,union
From: https://blog.csdn.net/2302_80639556/article/details/142298691

相关文章

  • AMD Instinct™ MI200 GPU内存空间概述
    AMDInstinct™MI200GPUmemoryspaceoverview—ROCmBlogs注意: 本博客之前是AMD实验室笔记博客系列的一部分。HIPAPI支持在加速系统上为主机和设备内存提供多种分配方式。在本文中,我们将:1.介绍一组常用的内存空间2.识别每种内存空间的独特之处3.讨论......
  • c#代码介绍23种设计模式_12亨元模式
    目录1、享元模式的实现精髓2、享元模式的正式定义3、亨元模式实现4、涉及的角色如下几种角色5、享元模式的优缺点6、使用场景7、实现思路在软件开发过程,如果我们需要重复使用某个对象的时候,如果我们重复地使用new创建这个对象的话,这样我们在内存就需要多次地去申请内......
  • c#代码介绍23种设计模式_13代理模式
    目录1、代理模式的详细介绍2、代理模式定义3、代理模式实现4、代理模式所涉及的角色5、代理模式的优缺点6、实现思路在软件开发过程中,有些对象有时候会由于网络或其他的障碍,以至于不能够或者不能直接访问到这些对象,如果直接访问对象给系统带来不必要的复杂性,这时候可......
  • 程序地址空间
    文章目录程序地址空间进程地址空间关于页表早期内存的分配方式程序地址空间计算机得物理内存大小是固定的,就是计算机主板内存槽上的实际物理空间,CPU可以直接继续寻址,物理内存的容量是固定的,但是寻址的卡空间取决于CPU地址线的数量。32位系统上,线性地址空间可达4G,那......
  • KMP算法
    引言之前在打ACM竞赛时就学过一些字符串相关的算法,其中就包括KMP。但是面向竞赛的KMP算法和面向408的KMP算法在一些概念和实现细节上有细微差异,所以特意写了这篇文章对408中的KMP算法做出总结字符串的前缀、后缀和部分匹配指前缀指除了最后一个字符以外,字符串的所有头部子串;后......
  • P10280 Cowreography G
    P10280CowreographyG贪心本题的证明中涵盖了多种证明方法:分类讨论,交换两个,整体策略,堪称贪心证明之典范符号约定令\(s_x\)表示最初字符串的不同\(1\)位置,\(t_x\)表示最终字符串的不同\(1\)位置Theorem1:交换\(a_i,a_j(i>j,a_i\nea_j)\)的最优步数为\(\lceil\fr......
  • P1939 矩阵加速
    P1939矩阵加速已知一个数列\(a\),它满足:\[a_x=\begin{cases}1&x\in\{1,2,3\}\\a_{x-1}+a_{x-3}&x\geq4\end{cases}\]求\(a\)数列的第\(n\)项对\(10^9+7\)取余的值。对于\(100\%\)的数据\(1\leqT\leq100\),\(1\leqn\leq2\times......
  • 记一次mysql导致服务器CPU突然暴涨的问题
    9月30号20点,感觉网站后台怎么越来越慢,打开阿里云看了服务器CPU竟然在几天内,一直是99%~100%,今天一天就觉得网站访问慢,还想着优化读取数据,原来CPU早就干爆了。想想有人攻击的话也不至于一直这样,putty上top一下,果然是mysql占满了CPU,大致查找策略如下 1、通过ps命令查找mysql进程......
  • 2024秋9月校测总结
    前言这段时间的校测考题都是基础,目的是让我们夯实基础以从10月开始进行提升训练!开始几天都考的dp题,难度中等,后面也考了ds和数学。总结dp的部分我不算是特别擅长,每次前面的题能够做出来但是后面有一定难度的题(蓝及以上)就不太能写,当然后面也慢慢好了一点,这段时间自己也找了......
  • [初中]我学不好语文,还能学好道法吗?
    可以首先放出我在同时期(八下期末)的语文和道法答题卡:看出来了吧,我的字不行我觉得,道法像是“简单版”的语文它也有答题模板,但使用的方法差异极大:在道法中有一种口号类的题目,模板是做法+意义,这时只需根据材料内容,结合所学知识,默写出相关“为什么类”知识点,再分角度答意义。......