本节书摘来自异步社区出版社《从缺陷中学习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配对,申请几次释放几次。
本文仅用于学习和交流目的,不代表异步社区观点。非商业转载请注明作译者、出处,并保留本文的原始链接。