1.共用体定义:
union 公用名 {
数据类型1 成员变量1;
数据类型2 成员变量2;
数据类型3 成员变量3;
..
};
注意: 1.结构体每个成员变量空间独立
2.共用体每个成员变量空间共享的
2.内存大小端
内存小端:内存低地址存放低数据位,内存高地址存放高数据位
内存大端:内存低地址存放高数据位,内存高地址存放低数据位
3.枚举类型:
enum 枚举类型名
{
枚举常量1,
枚举常量2,
枚举常量3,
..
};
注意:
1.枚举变量的值在枚举常量中选择其一作为它的值
2.枚举常量默认为int类型,第一个枚举常量的值默认为0,后续枚举常量的值为前一个枚举常量的值+1
2.位运算:
& 按位与 与0得0
| 按位或 或1置1
^ 按位异或 相同为0,相异为1
~ 按位取反
>> 右移 右移n位 = 缩小, 数据 / 2^n
<< 左移 左移n位 = 放大, 数据 * 2^n
将字节中第n位置1:
num = num | (1 << n);
将字节中第n位置0:
num = num & ~(1 << n);
不使用中间变量实现两个变量值的交换:
a = a ^ b;
b = a ^ b;
a = a ^ b;
内存管理:
1.malloc
void *malloc(size_t size);
功能:
申请堆区空间
参数:
size:申请堆区空间的大小
返回值:
成功返回堆区空间首地址
失败返回NULL
2.free
void free(void *ptr);
功能:
释放堆区空间
参数:
ptr:堆区空间首地址
返回值:
缺省
数组:
1.空间连续(访问数据方便、空间必须连续)
2.数组元素必须是有限
3.数组插入、删除元素效率低
链表:
1.空间不需要连续(访问数据麻烦、空间不需要连续,可以使用小的分散空间)
2.链表元素可以没有上限
3.链表插入、删除元素效率高
【无标题】
最新推荐文章于 2024-09-14 18:46:05 发布
本文详细介绍了C语言中的共用体、内存大小端的区别、枚举类型的特性,以及位运算的用法。同时探讨了malloc和free在内存管理中的作用,比较了数组和链表的不同优势。
摘要由CSDN通过智能技术生成