共用体
共用体的所有成员共享同一个内存地址
插入一个知识点:字符串不可以直接赋值,要不就在定义的时候赋值,要不就只能使用scanf函数赋值或者<string>中的strcpy赋值
证明
如果要同时访问联合体中多个成员的值......
则会出现以下情况
导致只有最后一个成员的数据打印出来才是正确的
因为三个成员都是引用同一个内存地址,所以对他们的赋值会导致成员数据的互相覆盖,只有在最后赋值的成员的值才是正确的
共用体占用的内存
边界对齐——4k
定义方式
初始化共用体
尽量不要同时初始化多个共用体的成员
** 共用体使用了内存覆盖技术,同一时刻只能保存一个成员的值,如果对新的成员赋值,就会把原来成员的值覆盖掉——用处:节省空间,**有两个很长的数据结构,不会同时使用,用共用体的话,只占用最长的那个数据结构所占用的空间。
枚举类型
第一个枚举常量的值默认为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更好,因为宏定义只是简单的替换,在使用我们定义的语句时只能定义第一个变量
如上图——简单的替换就会导致PTRINT b,c;变成int *b, c;
所以使用typedef更好
结构体和typedef
可修改为
STM32中常见知识点
进阶版
简单用法
版权归原作者 L1ve. 所有, 如有侵权,请联系我们删除。