free引起内核coredump的几种原因?

1.当前堆块儿越界,导致破坏下一个内存块儿。

2.前面的块儿越界,破坏了当前堆块儿。

3.double free 重复释放。

4.指针非法。free(p),p是不是malloc(或者strdup,calloc)返回的地址。

如何避免:

1.对于堆内存(类似malloc函数申请的)的操作,避免越界情况发生。一般对于字符串malloc申请内存时多申请一个字节用来存储字符串结束的‘\0',防止越界

char *p = malloc(size+1);
char *str = "123456789";
int size = strlen(str);

memset(p, 0x00, size+1);
memcpy(p, src, size);

2.养成好习惯。free前判断p是否为NULL,free(p)后对p置NULL。

...
if (p) {
    free(p);
    p = NULL;
}
...

3.不要对堆内存做p++操作。防止后面free(p)时,指针非法。

...
char *p = malloc(1024);
...
p++;
...
free(p);
...

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值