上个博客,笔者讲解了动态内存开辟函数:malloc函数!但是,仅仅光开辟空间还是不够的,如果一直进行空间的开辟,却不进行回收与释放,那么,再大的硬盘容量也经不起霍霍!!所以:动态内存的释放与回收函数:free()显得尤为重要!!
在C语言中,提供了一个函数:free()函数,专门用来做动态内存开辟空间的释放与回收的!!函数原型如下:
void free (void* ptr)
- free函数用来释放动态开辟的内存!!
- 1.如果参数ptr执行的空间,不是动态内存开辟的,那么free()函数的行为是未定义的!!
- 2.如果参数ptr是NULL指针,则函数什么事都不用做!
- malloc函数与free函数都是定义在:#include <stdlib.h>这个头文件中!!
将free与malloc函数的联用情况:
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
int main()
{
int* p = (int*)malloc(40);
int* ptr = p;
if (ptr == NULL)
{
printf("%s\n", strerror(errno));
return 1;
}
//使用
//自行添加使用的代码!!
//释放
free(p);
p = NULL;
}
在这个代码中,就是将malloc函数与free函数初步联用!!所以才能更合理的分配内存!!
但是在malloc函数与free函数联用的情况,由于代码的不规范,也会出现或多或少的错误!!
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
int test ()
{
int* p= (int*)malloc(40);
if (p == NULL)
{
printf("%s\n", strerror(errno));
return 1;
}
//使用
if (1)
{
//某个成立的条件!
return 2;
}
//释放
free(p);
p = NULL;
}//该段代码,存在内存泄露的问题!
int main()
{
test();
return 0;
其实,在该段代码中,可能出现内存泄漏的问题!!
原因在于:在该段代码中:
//使用
if (1)
{
//某个成立的条件!
return 2;
}
如果条件成立,直接返回该值,但并不会继续执行代码,导致,后续的释放(//释放 free(p); p = NULL;)出现问题!