《从缺陷中学习C/C++》——6.9 重复申请内存未释放

本节书摘来自异步社区出版社《从缺陷中学习C/C++》一书中的第6章,第6.9节,作者: 刘新浙 , 刘玲 , 王超 , 李敬娜 , ,更多章节内容可以访问云栖社区“异步社区”公众号查看。

6.9 重复申请内存未释放

从缺陷中学习C/C++
代码示例

unsigned char* Func(void)
{
  unsigned char *stra;
  stra = (unsigned char *)malloc(10);
  return stra;
}
int main()
{
  unsigned char *strb;
  strb = Func();  
  strb = (unsigned char *)malloc(10);
  free(strb);
  return 0;
}

现象&后果
用一个指针指向两次动态分配的内存,但只free一次,造成内存泄露。使用cppcheck工具检测,可以得到类似下面的信息:(error) Memory leak: strb。

Bug分析
Func函数中申请了内存赋值给strb, 然后在main函数中又动态分配了内存赋值给strb。在free(strb)时,实际只是释放了最后一次动态申请的内存,Func函数中申请的内存被漏掉了。第一次申请的内存没有被释放,造成内存泄露。

正确代码

unsigned char* Func(void)
{
  unsigned char *stra;
  stra = (unsigned char *)malloc(10);
  return stra;
}
int main()
{
  unsigned char *strb;
  strb = Func();free(strb);
  strb = (unsigned char *)malloc(10);
  free(strb);
  return 0;
}

编程建议
这是一个小问题。两次动态分配的内存,但只free一次,造成内存泄露。记得申请释放内存时要注意malloc和free配对,申请几次释放几次。

本文仅用于学习和交流目的,不代表异步社区观点。非商业转载请注明作译者、出处,并保留本文的原始链接。

上一篇:《从缺陷中学习C/C++》——6.8 指针释放后再次使用


下一篇:我的博客即将入驻“云栖社区”,诚邀技术同仁一同入驻。