啥是枚举?顾名思义,就是一一列举。枚举的关键词是enum。枚举类型的优点:增加代码可读性和可维护性。枚举有啥作用捏?请看如下:
enum Color
{
RED,//0,如果RED=5,下面紧跟着是5,6,7
GREEN,//1,如果GREEN=5,则是0,5,6
BLUE//2
};
int main()
{
//enum Color color = RED;
printf("%d\n", RED);
printf("%d\n", GREEN);
printf("%d\n", BLUE);
return 0;
}
看到这里是不是对枚举有了初步的了解?如果是:#define MALE 0类似这样,是没有类型可言的。且枚举是便于调试的,而define类型不可调试(预处理阶段会删除#define定义的符号);且枚举使用方便,一次可定义多个。
动态内存管理(hin重要,不管是c还是c++都会大量使用)
Int n=10;//申请四个字节 char c=’w’;//1个字节 char arr[20];//20个字节
Int arr[20];//80个字节
上述内存申请方式,一但申请好空间,大小就无法调整(不够灵活,不能申请动态内存)。
引入动态内存开辟,重要的4个函数!!!
Malloc,向内存申请一块可连续的空间,返回类型是void*。
int main()
{
//申请20个字节-存放五个整数
int* p = (int *)malloc(20);
if (p == NULL)
{
perror("malloc");
return 1;
}
//使用空间
int i = 0;
for (i = 0; i < 5; i++)
{
*(p + i) = i + 1;
}
//主动申请的空间用完了之后,释放内存,有借有还,用到free
free(p); //*p=i+1;p++;这样就不能free(p)了,容易出现bug。p已经不是起始地址了
p = NULL;//避免它成为野指针
return 0;
}
Free函数只有一个参数,使用来释放内存的。如果free指向的空间不是动态开辟的(例如malloc的动态开辟),那free函数的行为是未定义的。Free并不会改变p,而是把空间的使用权限还给了操作系统。
之前的概念:栈区(局部变量,形式参数);堆区(malloc,free,calloc,realloc);静态区(静态变量,全局变量)。
Calloc,函数的功能是为num个大小的size函数开辟一块空间,并且把空间的每个字节初始化0.
想初始化用calloc(会慢一点),不想初始化用malloc。
Realloc,让动态内存更加灵活,做出灵活的调整。例如:realloc(p,40);是将p调整为40个字节。Realloc(NULL,20)==malloc(20)。
这篇比较重要的就是通过代码来理解动态内存的管理。