您的位置:首页 > 编程语言 > C语言/C++

C语言中的复合数据类型

2016-07-25 11:15 246 查看
一、结构体

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.宏定义比较危险,如果重复定义的话会导致程序无法正常编译


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  关键字