常见的动态内存错误
1. 对NULL指针的解引用操作
- 代码实现:
void test()
{
1.int *p = (int *)malloc(INT_MAX/4);
*p = 20;//如果p的值是NULL,就会有问题
free(p);
}
- 画图实现:
- 补充知识:
#define INT_MAX 2147483647 //最大的无符号整型
2.对动态开辟内存空间的越界访问
- 代码实现:
void test()
{
int i = 0;
int *p = (int *)malloc(10*sizeof(int));
if(NULL == p)
{
exit(EXIT_FAILURE);
}
for(i=0; i<=10; i++)
{
*(p+i) = i;//当i是10的时候越界访问
}
free(p);
}
-
运行结果:
-
画图分析:
-
文字描述:
malloc开辟了10个int类型的空间
但是for循环进行了11次,导致了越界访问。
3.对非动态开辟内存使用free释放
- 代码实现:
void test()
{
int a = 10;
int *p = &a;
free(p);//ok?
}
- 运行结果:
-
画图分析:
-
文字描述:
局部变量是开辟在栈区的,不需要free;
强行free会报错;
4.使用free释放一块动态开辟的内存的一部分
- 代码实现:
void test()
{
int *p = (int *)malloc(100);
p++;
free(p);//p不再指向动态内存的起始位置
}
- 画图分析:
- 文字描述:
p++后,p指针将不再指向动态开辟内存的起始位置
5.对一块动态内存多次释放
void test()
{
int *p = (int *)malloc(100);
free(p);
free(p);//重复释放
}
- 文字描述:
p一开始指向动态内存开辟的100个字节,
但是free( p )之后,这100个字节将返还给操作系统,
此时再free ( p )将报错,
因此我们写代码的时候要养成一个好习惯,
free( p )之后,再将p = NULL.
6.动态开辟内存忘记释放(内存泄漏)
- 代码实现:
void test()
{
int *p = (int *)malloc(100);
if(NULL != p)
{
*p = 20;
}
}
int main()
{
test();
while(1);
}
- 文字描述:
忘记释放不再使用的动态开辟的空间会造成内存泄漏。
切记:
动态开辟的空间一定要释放,并且正确释放 。
结语:
感谢大家看到这里,如有错误,希望各位大佬多多指正!
祝大家心情愉悦!