动态内存管理——常见错误
//——————常见的动态内存错误
——1 对NULL指针的解引用操作
//void test()
//{
//?? ?int* p = (int*)malloc(40);
//?? ?*p = 20;//如果p的值是NULL,就会有问题,所以在使用malloc、realloc、calloc时的返回值p进行相关的检测。
// //为空指针,代码就此结束(return即可)
//?? ?free(p);
//}
——2 对动态开辟空间的越界访问
//#include<stdio.h>
//#include<stdlib.h>
//#include<errno.h>
//void test()
//{
//?? ?int i = 0;
//?? ?int* p = (int*)malloc(10 * sizeof(int));
//?? ?if (NULL == p)
//?? ?{
//?? ??? ?printf("%s\n",strerror(errno));
//?? ?}
//?? ?for (i = 0; i <= 10; i++)//可循环11次,返回值p会越界(44>40)
//?? ?{//i应为i<10
//?? ??? ?*(p + i) = i;//当i是10的时候越界访问。*(p+i)=p[i]
//?? ?}
//?? ?free(p);
//}
——3 对非动态开辟内存使用free释放
//void test()
//{
//?? ?int a = 10;
//?? ?int* p = &a;//此时p指向的是栈区的空间,并不是动态开辟出来的。
//?? ?free(p);//而free释放的只能是malloc、calloc、realloc所拿到的空间
//}
——4 使用free释放一块动态开辟内存的一部分
//#include<stdio.h>
//#include<stdlib.h>
//void test()
//{
//?? ?int* p = (int*)malloc(100);
//?? ?int i=0;//此时返回值p在被释放的时候并没有指向起始位置(free不可以只释放其中一部分)
//?? ?for (i = 0; i < 10;i++)
//?? ?{
//?? ??? ?*p = i;
//?? ??? ?p++;
//?? ?}
//?? ?free(p);//p不再指向动态内存的起始位置
// ? ?p=NULL;//不可以用const去保护p,因为怕、还要被赋值为NULL
//}
——5 对同一块动态内存未赋值NULL之前再次释放
//void test()
//{
//?? ?int* p = (int*)malloc(100);
//?? ?free(p);//加一句赋值NULL即可
//?? ?free(p);//释放空指针无意义,但不会报错,若不赋值NULL,则p被回收后再次释放时,空间已被回收,
// ?//但p中依然存着原来的地址,导致p为野指针,也无法进行任何操作。
//}
——6 动态开辟内存忘记释放(内存泄漏:内存用完不还)
例一
//#include<stdlib.h>
//void test()
//{
//?? ?int* p = (int*)malloc(100);
//?? ?int flag=0;
//?? ?if (flag == 5)//当flag=5时,申请的空间用完后不会被释放,倒是内存泄漏
//?? ??? ?return;
//?? ?free(p);
//?? ?p = NULL;
//}
//int main()
//{
//?? ?test();
//?? ?return 0;
//}
例二
//#include<stdlib.h>
//int ?test()
//{
//?? ?int* p = (int*)malloc(100);
//?? ?int flag=0;
//?? ?if (flag == 5)//当flag=5时,申请的空间用完后不会被释放,倒是内存泄漏
//?? ??? ?return p;
//}
//int main()
//{
//?? ?int* ret=test();
//?? ?//函数将返回的地址赋给新的变量,但是赋值后没有进行释放
//?? ?return 0;
//}
注意:忘记释放不再使用的动态开辟的空间会造成内存泄漏。
? ? ?动态开辟的空间一定要释放,并且正确释放。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!