malloc,calloc,realloc动态内存管理函数的出现解决了在某些c语言标准中不能使用变长数组的问题
这三个函数的使用需要头文件stdlib.h,这些函数开辟的空间在堆区,系统不会自动释放,需要手动管理释放。
malloc:向内存申请一块空间,不初始化该空间
参数:想要开辟的空间的大小
返回值:返回该空间的起始地址
使用举例:
int main()
{
int* p = (int*)malloc(5 * sizeof(int));
if (p == NULL)
return;
int i = 0;
for (i = 0; i < 5; i++)
{
p[i] = i;
printf("%d ", p[i]);
}
free(p);//释放空间
p = NULL;//p置空,防止野指针
return 0;
}
calloc:向堆区申请一块内存,且进行初始化为0
参数:calloc的参数与realloc不同,有两个,第一个参数是个数,第二个是每一个的大小。
但是注意calloc开辟的空间还是连续的
返回值:返回该空间的起始地址
int main()
{
int* p = (int*)calloc(5,sizeof(int));
if (p == NULL)//开辟内存失败会返回空指针
return;
free(p);//释放空间
p = NULL;//p置空,防止野指针
return 0;
}
calloc与realloc的区别就是参数格式的区别与是否初始化
realloc:如果想要扩大或者缩小calloc或者malloc开辟的内存,使用realloc.
realloc的第一个参数是维护某一块内存的指针,第二个参数是想要重新设置的内存大小(注意不是增加的内存大小),该函数的返回值是重新设置的那块内存的起始地址
int main()
{
int* p = (int*)malloc(5 * sizeof(int));
if (p == NULL)
return 0;
int i = 0;
for (i = 0; i < 5; i++)
{
p[i] = i;
printf("%d ", p[i]);
}
int* tmp = (int*)realloc(p, 10 * sizeof(int));
if (tmp == NULL)//realloc可能调整失败
return 0;
p = tmp;
for (i = 5; i < 10; i++)
{
p[i] = i;
printf("%d ", p[i]);
}
free(p);
p = NULL;
return 0;
}
realloc如果是重新调整空间使原来空间变小的话,之间在原来的空间进行调整。但是如果realloc是扩大空间的话有两种情况
扩容是有成本的,会占用系统开销,不建议频繁扩容