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.

Run this test again Return to test menu

Historical Results

Based on (13) saved test runs, The test labeled "strncmp()" was (on average) the faster by 0.016 seconds, (1.725% faster)

strncmp() 100%
strpos() 98.275%

The strncmp() test took 0.9118 seconds.
The strpos() test took 0.9278 seconds.

Nitty-Gritty

Each test case ran 20 random code order iterations consisting of 233,428 loops for a total of 4,668,565 runs.

  • Line execution difference (0.000003) milliseconds.
  • Avg difference (0.000) milliseconds per 233,428 loops.
  • Total difference 16.00 milliseconds for 4,668,565 loops

The iteration variablity for Code 1 was (0.0000) milliseconds and Code 2 was (0.0000) 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)