C语言之共用体、枚举类型、typedef

共用体

共用体的所有成员共享同一个内存地址

C语言之共用体、枚举类型、typedef_第1张图片

 插入一个知识点:字符串不可以直接赋值,要不就在定义的时候赋值,要不就只能使用scanf函数赋值或者中的strcpy赋值

证明

C语言之共用体、枚举类型、typedef_第2张图片

 C语言之共用体、枚举类型、typedef_第3张图片

如果要同时访问联合体中多个成员的值......

C语言之共用体、枚举类型、typedef_第4张图片

 则会出现以下情况

C语言之共用体、枚举类型、typedef_第5张图片

导致只有最后一个成员的数据打印出来才是正确的

因为三个成员都是引用同一个内存地址,所以对他们的赋值会导致成员数据的互相覆盖,只有在最后赋值的成员的值才是正确的

共用体占用的内存

边界对齐——4k

C语言之共用体、枚举类型、typedef_第6张图片

定义方式

C语言之共用体、枚举类型、typedef_第7张图片

C语言之共用体、枚举类型、typedef_第8张图片

初始化共用体 

尽量不要同时初始化多个共用体的成员

 共用体使用了内存覆盖技术,同一时刻只能保存一个成员的值,如果对新的成员赋值,就会把原来成员的值覆盖掉——用处:节省空间,有两个很长的数据结构,不会同时使用,用共用体的话,只占用最长的那个数据结构所占用的空间。

枚举类型

 

 

 第一个枚举常量的值默认为0,默认情况下是从0开始定义的(枚举值实际上是从0开始的整数)

 

即sun的值为0,mon的值默认为1,tue为2,以此类推......

我们还可以改变其中的枚举值

red的值为10,则green的值为11,blue的值为12

red的值为0,green为1,blue为10,yellow为11。

typedef

typedef和宏定义的区别——宏定义是硬核的替换,而typedef是对类型的封装

当我们宏定义和typedef int类型之后,在使用时想加入前缀unsigned时,宏定义是可以成功的,但是typedef不行,必须把unsigned也封装进去;

当我们想对int *指针类型封装时,使用typedef更好,因为宏定义只是简单的替换,在使用我们定义的语句时只能定义第一个变量

C语言之共用体、枚举类型、typedef_第9张图片

如上图——简单的替换就会导致PTRINT b,c;变成int *b, c;

所以使用typedef更好

结构体和typedef

C语言之共用体、枚举类型、typedef_第10张图片

可修改为

C语言之共用体、枚举类型、typedef_第11张图片

STM32中常见知识点 

进阶版

简单用法

C语言之共用体、枚举类型、typedef_第12张图片

 

你可能感兴趣的:(c语言,开发语言)