C语言中的复合数据类型

来源:互联网 发布:成都程序员 编辑:程序博客网 时间:2024/05/17 23:47

一、结构体

1.作用:封装数据,把多种不同的数据类型放在一起

2.定义:一般放在全局,定义时不要忘记在结尾的“}”后加上“;”

3.初始化

分为静态初始化和动态初始化

在动态初始化时要注意:

①给结构体中的数组成员赋值时,不能直接将字符串赋给数组名,可以使用strcpy函数

②给结构体中的指针变量成员赋值时,要先给指针分配空间,否则它会使一个野指针

静态初始化即在定义的时候直接赋值

结构体数组的初始化:使用for循环来完成

4.结构体中的对齐方式:字对齐和半字对齐

字对齐:给每个变量先分配四个字节的空间,如果下一个数据的数据类型与之相同,就可以放在一起,如果空间不够就再开辟四个字节的空间;如果类型不相同,就直接开辟四个字节的空间

半字对齐:原理和字对齐大致相同,但是分配的空间为2个字节

内存空洞:由于字对齐和半字对齐造成的内存浪费
解决方法:在定义结构体的时候,尽量将相同类型的数据放在一起

二、共用体

1.和结构体的区别
共用体的大小是其中最长的数据类型的长度,共用体中所有的成员共用同一段内存空间,但是其也满足字对齐和半字对齐

2.使用共用体会造成数据覆盖,例如:
union stu
{
    int num;
    char ch;
};

union stu p;

p.num = 1;
p.ch = 'a';

printf("p.num = %d\n",p.num);

这段代码的结果为p.num = 97,是因为后面赋值的ch覆盖了num,即输出了’a’的ASCII码值

3.大端字节和小段字节

大端字节和小段字节是CPU的属性,与操作系统无关

小端字节:低字节存放在低地址,高字节存放在高地址
大端字节:高字节存放在低地址,低字节存放在高地址

无论大端字节还是小端字节,都是从低字节开始存放的

使用共用体来验证CPU的大小端
union node
{
    int num;
    char ch;
}

int main()
{
    union node p;
   
    p.num = 0x12345678;
   
    if(ch == 78)
    {
        printf("Small!\n");
    }
    else
    {
        printf("Big!\n");
    }
    return 0;
}

三、枚举变量

枚举变量的实质是一串整数宏

作用:杜绝幻数,提高代码可读性

什么时候使用:需要大量整数宏的时候

枚举变量和宏定义的区别:

1.枚举属于常量;但宏定义不是常量

2.枚举常量是实体的一种;但宏定义不是实体

3.从作用域上来看,宏没有作用域,只是一种单纯的替换,而枚举变量具有作用域

4.枚举变量只能用来定义整数宏

5.宏定义比较危险,如果重复定义的话会导致程序无法正常编译


0 0