- 对NULL指针的解引用 *** 作
- 对动态开辟内存空间的越界访问
- 对非动态开辟内存使用free释放
- 使用free释放一块动态开辟的内存的一部分
- 对一块动态内存多次释放
- 动态开辟内存忘记释放(内存泄漏)
- 代码实现:
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次,导致了越界访问。
- 代码实现:
void test()
{
int a = 10;
int *p = &a;
free(p);//ok?
}
- 运行结果:
-
画图分析:
-
文字描述:
局部变量是开辟在栈区的,不需要free;
强行free会报错;
- 代码实现:
void test()
{
int *p = (int *)malloc(100);
p++;
free(p);//p不再指向动态内存的起始位置
}
- 画图分析:
- 文字描述:
p++后,p指针将不再指向动态开辟内存的起始位置
void test()
{
int *p = (int *)malloc(100);
free(p);
free(p);//重复释放
}
- 文字描述:
p一开始指向动态内存开辟的100个字节,
但是free( p )之后,这100个字节将返还给 *** 作系统,
此时再free ( p )将报错,
因此我们写代码的时候要养成一个好习惯,
free( p )之后,再将p = NULL.
- 代码实现:
void test()
{
int *p = (int *)malloc(100);
if(NULL != p)
{
*p = 20;
}
}
int main()
{
test();
while(1);
}
- 文字描述:
忘记释放不再使用的动态开辟的空间会造成内存泄漏。
切记:
动态开辟的空间一定要释放,并且正确释放 。
感谢大家看到这里,如有错误,还请大家多多指正,博主一定虚心改正。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)