检测并删除Linux应用程序中的内存泄漏

我们有一个非常大的项目,它基本上是一个使用Linux Application编程并在PowerPC处理器上运行的应用程序.该项目最初是由另一家公司开发的.我们从公司收购了该项目,现在我们正在维护该项目.

据报告该应用程序存在很多内存泄漏问题.由于这是一个大型项目,因此无法转到每个源代码文件并找出内存泄漏.我们已经使用了Valgrid,mpatrol和其他内存泄漏检测工具.这些工具没有太大帮助,内存泄漏也没有显着减少.

在这种情况下,如何大幅度减少内存泄漏.除上述内存泄漏检测工具外,人们是否有在这种情况下使用的通用方法来减少内存泄漏.

最佳答案
通常,Valgrind属于执行此任务的最佳工具.如果无法正常工作,则可能只有几件事仍然可以做.

>第一个问题:应用程序使用哪种语言? Valgrind对于C和C非常有用,但是在垃圾回收或脚本语言方面无济于事.因此,请先检查语言. Java可能有一些类似的东西,但是我没有使用太多的Java,因此您不得不问其他人.
>使用valgrind的设置玩很多.有几个插件可以帮助您解决这个问题.一个示例可以使用–leak-check = full或类似的选项.还有用于valgrind的插件,可以增强其检测功能.
>您说,据报告该应用程序存在内存泄漏.如何检测到的?应用程序是否自行检测到此错误.如果应用程序自己检测到它,而没有任何外部工具,则可能意味着有人在应用程序内部添加了自己的内存跟踪器.自定义内存跟踪器,内存池等会使valgrind混乱,并且任何其他泄漏检测系统都非常糟糕.因此,如果应用程序中存在任何自定义内存处理,则您唯一的选择是停用它(如果可能)或挂接到该自定义机制.如何完成此操作仅取决于您的应用程序.
>添加您自己的内存跟踪器.例如,在C语言中,可以挂接到新的/删除的调用中并使它们跟踪内存.您可以使用几个库.您也可以在大约500 LOC中编写自己的新/删除替换.如果您决定使用此方法,请务必阅读大量有关替换new / delete的教程,因为在尝试执行此任务时,C世界中有许多不寻常的事情.
>是什么让您确定应用程序中存在内存泄漏(即如何检测到)?如果某个工具仅报告了大量已分配的内存,则这甚至可能并不意味着存在实际的内存泄漏.内存泄漏意味着丢失了内存句柄,因此不可能到达每个范围并再次释放该内存.如果您的应用程序仅获得大量内存并保持可访问性,那么您可能会遇到完全不同的问题.例如,您可能只是在某一点或另一点使用空间复杂度较差的算法,从而导致许多分配.在这种情况下,您将不需要泄漏检测器,而是需要一个内存探查器,它可以为您提供代码部分的内存占用的更详细的概述.但是,我之前从未使用过探查器来执行此类任务,因此我无法再给您任何提示.

转载注明原文:检测并删除Linux应用程序中的内存泄漏 - 代码日志