常见的动态内存错误【C语言】

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);
}
  • 文字描述:
    忘记释放不再使用的动态开辟的空间会造成内存泄漏。
    切记:
    动态开辟的空间一定要释放,并且正确释放 。

结语:

感谢大家看到这里,如有错误,希望各位大佬多多指正!
祝大家心情愉悦!
在这里插入图片描述

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值