Project

General

Profile

« Previous | Next » 

Revision 7571ad42

Added by peterzhu2118 (Peter Zhu) 11 months ago

[Bug #20650] Fix memory leak in Regexp capture group when timeout (#11244)

Fix memory leak in Regexp capture group when timeout

[Bug #20650]

The capture group allocates memory that is leaked when it times out.

For example:

re = Regexp.new("^#{"(a*)" * 10_000}x$", timeout: 0.000001)
str = "a" * 1000000 + "x"

10.times do
  100.times do
    re =~ str
  rescue Regexp::TimeoutError
  end

  puts `ps -o rss= -p #{$$}`
end

Before:

34688
56416
78288
100368
120784
140704
161904
183568
204320
224800

After:

16288
16288
16880
16896
16912
16928
16944
17184
17184
17200