89

多くの開発者がstrstrとstrposの両方を使用してサブストリングの存在をチェックしていることに気づきました。それらの1つが優先され、その理由は何ですか?

4

5 に答える 5

131

PHPオンラインマニュアルから:

strpos() 特定の針が干し草の山の中で発生するかどうかだけを判断したい場合は、代わりに、より高速でメモリをあまり消費しない関数を使用してください。

于 2011-04-28T14:55:51.583 に答える
41

ここに私が私の質問にたどり着いた他のいくつかの答え(+ベンチマーク)があります、それはほとんど同じです(私は尋ねたときにあなたの答えに気づいていませんでした)。


その間に、私は独自のベンチマークテストも作成しました。これは、関連する関数(、、、および)ごとに1000000回実行しstrstr()ました。 コードは次のとおりです。strpos()stristr()stripos()

<?php

function getmicrotime() {
    list($usec, $sec) = explode(" ", microtime());
    return ((float) $usec + (float) $sec);
}

$mystring = 'blahblahblah';  
$findme = 'bla';  

echo 'strstr & strpos TEST:<pre>';
$time_start = getmicrotime();
for($i=0; $i<1000000; $i++) strstr($mystring, $findme);
$time_needed_strstr = getmicrotime() - $time_start;
echo 'strstr():            ',
    round( $time_needed_strstr , 8 ). PHP_EOL;

$time_start = getmicrotime();
for($i=0; $i<1000000; $i++) stristr($mystring, $findme);
$time_needed_stristr = getmicrotime() - $time_start;
echo 'stristr():           ',
    round( $time_needed_stristr , 8 ) . PHP_EOL;

$time_start = getmicrotime();
for($i=0; $i<1000000; $i++) strpos($mystring, $findme) !== false;
$time_needed_strpos = getmicrotime() - $time_start;
echo 'strpos() !== false:  ',
    round( $time_needed_strpos , 8 ) . PHP_EOL;

$time_start = getmicrotime();
for($i=0; $i<1000000; $i++) stripos($mystring, $findme) !== false;
$time_needed_stripos = getmicrotime() - $time_start;
echo 'stripos() !== false: ',
    round( $time_needed_stripos , 8 ) . PHP_EOL;

echo PHP_EOL;

echo 'time_needed_stristr - time_needed_strstr: ',
     round( $time_needed_stristr - $time_needed_strstr , 8) . PHP_EOL;
echo 'time_needed_stripos - time_needed_strpos: ',
     round( $time_needed_stripos - $time_needed_strpos , 8) . PHP_EOL;

echo PHP_EOL;

echo 'time_needed_strstr  - time_needed_strpos:  ',
     round( $time_needed_strstr - $time_needed_strpos , 8) . PHP_EOL;
echo 'time_needed_stristr - time_needed_stripos: ',
     round( $time_needed_stristr - $time_needed_stripos , 8) . PHP_EOL;

echo '</pre>';

?>

そして、これが最初の出力であり、それstrpos()が勝者であることを示しています。

strstr & strpos TEST:
strstr():            2.39144707
stristr():           3.65685797
strpos() !== false:  2.39055395
stripos() !== false: 3.54681897

time_needed_stristr - time_needed_strstr: 1.2654109
time_needed_stripos - time_needed_strpos: 1.15626502

time_needed_strstr  - time_needed_strpos:  0.00089312
time_needed_stristr - time_needed_stripos: 0.110039 

次のものは最初の出力に似ています(strpos()再び勝者です):

strstr & strpos TEST:
strstr():            2.39969015
stristr():           3.60772395
strpos() !== false:  2.38610101
stripos() !== false: 3.34951186

time_needed_stristr - time_needed_strstr: 1.2080338
time_needed_stripos - time_needed_strpos: 0.96341085

time_needed_strstr  - time_needed_strpos:  0.01358914
time_needed_stristr - time_needed_stripos: 0.25821209

以下はもう1つです。この場合strstr()は勝者であるため、さらに興味深いものです。

strstr & strpos TEST:
strstr():            2.35499191
stristr():           3.60589004
strpos() !== false:  2.37646604
stripos() !== false: 3.51773095

time_needed_stristr - time_needed_strstr: 1.25089812
time_needed_stripos - time_needed_strpos: 1.14126492

time_needed_strstr  - time_needed_strpos:  -0.02147412
time_needed_stristr - time_needed_stripos: 0.08815908

つまり、実際には影響を受けにくい「環境状況」に依存する可能性があり、文字列が別の文字列に存在するかどうかを確認するだけの場合は、このような「マイクロ最適化タスク」の結果が変わる可能性があります。

しかし、私はほとんどの場合、strpos()と比較して勝者strstr()だと思います。

このテストが誰かに役立つことを願っています。

于 2011-04-28T19:10:48.010 に答える
7

多くの開発者は、マイクロ最適化の目的で使用strposます

また、使用strstrは、結果の文字列がブールコンテキストでfalseとして解釈できない場合にのみ機能します。

于 2011-04-28T14:56:36.207 に答える
0

strpos()は、干し草の山のどこに特定の針があるかを検出します。stristr()は、針が干し草の山のどこかにあるかどうかをテストします

そのため、strpos()はより高速で、メモリ消費量が少なくなります

strstr()の理由:針が文字列の先頭にある場合、strposは0を返します(したがって、=== falseでチェックする必要があります)

于 2011-04-28T14:56:35.203 に答える
-2

strstr()私は読みやすさと簡単なコーディング を好みstrpos() !==false ます..少し混乱しています..

于 2014-12-19T16:35:39.230 に答える