PHP Benchmarks

Performance comparison of PHP code alternatives.

Test: array_walk vs. array_walk_recursive

Does the recursive variant have any benefit over rolling our own recursion?

View test history (2) Run this test again Return to test menu

Result: Discarded

The test labeled "array_walk_recursive()" was the faster by 0.0197 seconds, (2.727% faster)

array_walk_recursive() 100%
array_walk() 97.273%

The array_walk_recursive() test took 0.7028 seconds.
The array_walk() test took 0.7225 seconds.

Nitty-Gritty

Each test case ran 20 random code order iterations consisting of 167,487 loops for a total of 3,349,740 runs.

  • Line execution difference (0.000006) milliseconds.
  • Avg difference (0.985) milliseconds per 167,487 loops.
  • Total difference 19.71 milliseconds for 3,349,740 loops

The iteration variablity for Code 1 was (5.9731) milliseconds and Code 2 was (5.4679) milliseconds. The lower and the closer together there values are the more accurate the results are.

Code

The first test, "array_walk()", was:

/*
function foo_manual(&$v)
{
	if (is_array($v))
		array_walk($v, 'foo_manual');
	else
		$v++;
}
*/

array_walk($GLOBALS['dummy'], 'foo_manual');

The second test, "array_walk_recursive()", was:

/*
function foo_auto(&$v)
{
	$v++;
}
*/

array_walk_recursive($GLOBALS['dummy'], 'foo_auto');

Running: Linux (x86_64:1 GB) PHP (7.2.25-1+ubuntu16.04.1+deb.sury.org+1)