来自匹配运算符的Perl内存泄漏

时间:2011-09-30 08:30:51

标签: perl debugging memory-leaks

在研究长期运行的perl程序是否存在内存泄漏时,我尝试使用Test::LeakTrace

查看其报告的泄漏之一,我可以将泄漏的代码缩小到:

/$?/

正在运行:perl -MTest::LeakTrace::Script -e'/$?/'打印:

从-e line 1泄露了SCALAR(0x10d3d48)。

为什么会这样,我需要担心吗?

更新:还尝试了Devel::LeakTrace::Fast,它没有抱怨相同的代码。

1 个答案:

答案 0 :(得分:2)

假设你有泄漏。然后这个:

perl -e'/$?/ for 1..1E9'

应该让你的过程在内存中增长

 ps -o rss,vsz <PID>

在我的情况下,它一直保持稳定。您应该检查它以进行设置。可能是您的模块检测到的泄漏是一些晚期破坏。你可以给模块作者写一个注释来帮助你找出它的输出,你可以帮助他们改进它......

BTW另一件确认“没有泄漏”的事情是

 perl -MTest::LeakTrace::Script -e'/$?/ for 1..1000'

我没有看到多个泄露的标量,只有一个。