

结构体
A.声明一个结构体

struct-结构体关键字 stu-结构体标签 char name[20]-成员变量

B.匿名结构体类型


这里分别创建的*psa和sa分别是独立创建的两个类型,两者类型不同,所以这里psa=&sa是无法指向sa的地址的。
C.结构体的自引用


错误,不能结构体声明是再其中包含自己。内存无法确定。

正确

D.typedef

正确

错误
这里只是将结构体类型重新命名为Node,并未定义变量,而这又是匿名结构体类型所以错误。
结构体内存对齐


struct s1

struct s2

练习
1.

答案16
2.


答案32


第一种
读取c要1次 读取a要2次
第二种
读取c要1次 读取a要1次(效率更高)



Tip1.
offsetof()-计算成员变量关于起始位置的偏移量-头文件#include<stddef.h>
offsetof()是宏

F.结构体传参

这里指进行了传值而未传址,所以二者内存地址不同,故对tmp的改变不会影响主函数中的s。



G.位段(用于节省空间)-

其实long,short,char也行,不过类型通常要相似的,不能一会char,一会int。


这里a只要2个比特位,b只要5个比特位,c只要10个比特位,d只要30个比特位。
如果不设置位段这里a是int类型,有32个比特位,有2^32种,但你不需要这么多种
所以设置位段来限制比特位。(位段给的数字要<=32)

3.因为C语言未给位段定标准,所以不同编译器对其理解是不同的,如存储是是从左开始存还是右开始存,或是多余的空间是否浪费。



在内存中表示是以十六进制表示的每四个比特位表示一个数所以最后是220304


2.枚举
A.枚举的使用






这里虽然可以编译过去但其实是有问题的因为左边的是枚举类型,右边的是int类型。
B.枚举的优点

枚举类型的大小一般4字节,不存在对齐这一概念
3.联合(共用体)


联合体的成员不能同时使用如果使用c,就不能用i。因为它们内部空间互相干涉。

利用联合体判断大小端


数组的对齐数大小是它元素的大小
