xhprof
xhprof copied to clipboard
PHP80 / Possible memory leak on array_filter vs opcache
I've experienced a memory leak using array_filter
when both opcahe and xhprof are enabled.
here is a demo script:
<?php
// array_filter_short.php
namespace Somewhere\On\Earth;
class Foo {
function leaking(array $array) {
$f = function ($array) {
return \array_filter($array, fn($item) => !is_null($item));
};
for (;;) {
$clone = (array) $array;
$res = $f($clone);
printf("memory: %d\n", \memory_get_usage());
unset($clone, $res);
}
}
function run() {
$array = array_combine(range(1, 1000, 2), array_fill(1, 500, null));
$array += array_combine(range(2, 1000, 2), array_fill(1, 500, true));
$this->leaking($array);
}
}
(new Foo())->run();
Test it with
php80 -n -dzend_extension=opcache -dopcache.enable=1 -dopcache.enable_cli=1 -dextension=xhprof.so array_filter_short.php
Here is the PHP bug I've filled https://bugs.php.net/bug.php?id=81215