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

    xiaoxiao2024-10-07  77

    本节书摘来自异步社区出版社《从缺陷中学习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配对,申请几次释放几次。

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

    最新回复(0)