上个博客,笔者讲解了动态内存开辟函数: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;)出现问题!