最近做项目的时候,在一个C++项目,增加了一个功能。测试发现内存泄漏严重,较长时间才解决。有了一点点心得。
内存泄漏解决的办法:
- 代码回退。新增的功能代码,完全绕过,测试有无问题。如果有问题,那就说明之前就有问题。如果没有问题,那就确定是新增代码有问题。在新增代码里,也是如此这般确定代码,即由大到小的绕过(注释),如果发现某个代码块有问题,在进入更小粒度的debug。
- 尽情的free变量。相比内存泄漏,内存溢出更容易发现,因为溢出时会报段错误,生成coredump文件,通过gdb就能定位到错误,而内存泄漏是不断从系统申请内存,直到没有内存可用的时候,系统将进程杀掉,什么错误也没有报。内存监控会发现系统内存可用空间越来越小。所以不确定某个变量是否引起内存泄漏,那就先开启free,段错误发生再说。可以一发现内存泄漏,极端的将各种变量free。段错误发生时,再一点点去掉free。注意,要注意有些变量是一个多层级的变量,即有子变量,甚至有孙子变量,重孙子变量,...,free的时候,要先free最底层的,往上逐层free。如果只free最上层的变量,这种方法就失灵了,还是发现不了内存泄漏。
内存泄漏,不易debug。debug过程虽然痛苦,但是可以学到C++的很多深层次知识。祝福每一个苦苦debug的同学!