PHP Benchmarks

Performance comparison of PHP code alternatives.

Test: strncmp vs. strpos (short)

10 character string, check if a substring exists in a defined location with both pass and fail paths.

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

Result: Saved

The test labeled "strncmp()" was the faster by 0.0084 seconds, (0.795% faster)

strncmp() 100%
strpos() 99.205%

The strncmp() test took 1.0481 seconds.
The strpos() test took 1.0565 seconds.

Nitty-Gritty

Each test case ran 20 random code order iterations consisting of 283,686 loops for a total of 5,673,720 runs.

  • Line execution difference (0.000001) milliseconds.
  • Avg difference (0.420) milliseconds per 283,686 loops.
  • Total difference 8.40 milliseconds for 5,673,720 loops

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

Code

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

for ($j = 0; $j < 40; $j++)
	$GLOBALS['dummy'] = strncmp($GLOBALS['dummy_match'], '01234', 5) === 0;
for ($j = 0; $j < 40; $j++)
	$GLOBALS['dummy'] = strncmp($GLOBALS['dummy_fail'], '01234', 5) === 0;

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

for ($j = 0; $j < 40; $j++)
	$GLOBALS['dummy'] = strpos($GLOBALS['dummy_match'], '01234') === 0;
for ($j = 0; $j < 40; $j++)
	$GLOBALS['dummy'] = strpos($GLOBALS['dummy_fail'], '01234') === 0;

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