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.宏定义比较危险,如果重复定义的话会导致程序无法正常编译
- C语言中的复合数据类型
- C语言复合数据类型
- 15.8 C语言复合数据类型
- C语言学习之复合数据类型
- C语言中的数据类型
- C语言中的数据类型
- C语言中的数据类型
- C 语言中的数据类型
- C语言中的数据类型
- C语言中的数据类型
- C语言中的数据类型
- c语言中的数据类型
- c语言==复合数据类型(14)
- C语言 复合数据类型(结构体 共用体 枚举)
- C语言中的基本数据类型
- C语言中的基本数据类型
- C语言中的基本数据类型
- C语言中的基本数据类型
- QT on Android开发
- 一个炒鸡好用的 indicator 开源指示器
- 【9910】竞赛总分
- Linux下远程桌面Windows
- Qt for Android 打包 SQLite 数据库
- C语言中的复合数据类型
- java.lang.RuntimeException: Unable to instantiate application com.android.tools.fd.runtime.Boo
- http://blog.csdn.net/whuslei/article/details/6667471/
- KS8U读卡器
- aspcms留言增加防刷新验证,单一ip留言条数限制,防止恶意刷新及恶意提交。
- 李开复:年轻人该比谁更拼命吗?
- MF-800U
- R语言与机器学习学习笔记(分类算法)(3)朴素贝叶斯
- UHF桌面式发卡器