PHP Benchmarks

Performance comparison of PHP code alternatives.

Test: foreach (fcall) vs. foreach ($temp)

Is the array being iterated cached? It could cause some nasty side effects to OOP if it is, but maybe PHP is smart about this.

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

Result: Discarded

The test labeled "foreach (fcall)" was the faster by 0.0238 seconds, (2.429% faster)

foreach (fcall) 100%
foreach ($temp) 97.571%

The foreach (fcall) test took 0.9549 seconds.
The foreach ($temp) test took 0.9787 seconds.

Nitty-Gritty

Each test case ran 20 random code order iterations consisting of 261,205 loops for a total of 5,224,100 runs.

  • Line execution difference (0.000005) milliseconds.
  • Avg difference (1.189) milliseconds per 261,205 loops.
  • Total difference 23.78 milliseconds for 5,224,100 loops

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

Code

The first test, "foreach (fcall)", was:

foreach (array_merge(range(1, 10), range(11, 20), range(21, 30), range(31, 40)) as $v)
	$GLOBALS['dummy2'] = $v;

The second test, "foreach ($temp)", was:

$temp = array_merge(range(1, 10), range(11, 20), range(21, 30), range(31, 40));
foreach ($temp as $v)
	$GLOBALS['dummy2'] = $v;

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