一般に、配列を走査するには、for、while、および foreach の 3 つのメソッドがあります。その中で最もシンプルで便利なのは foreach です。では、それらの操作とパフォーマンスにはどのような違いがあるのでしょうか?通常、どちらの方法を使用するのが良いでしょうか?
まず、50,000 個の添字を持つ 1 次元配列を走査するのにかかる時間をテストしてみましょう。
テスト プラットフォーム:
CPU:PM725
メモリ: 512M
ハードドライブ: 40G 5400 rpm
OS:Windows XP SP2
WEB: apache 2.0.54 php5.0.4
テストコード:
<?php
/*
* @著者:リロフ
* @ ホームページ: www.codesky.com
* @電子メール: [email protected]
*
*/
$arr = 配列();
for($i = 0; $i < 50000; $i++){
$arr[] = $i*rand(1000,9999);
関数
GetRunTime()
{
list($usec,$sec)=explode(" ",microtime());
return ((float)$usec+(float)$sec);
}
#####################################
$time_start = GetRunTime();
for($i = 0; $i < count($arr); $i++){
$str .= $arr[$i];
$
time_end = GetRunTime();
$time_used = $time_end - $time_start;
echo '使用時間:'.round($time_used, 7).'(s)<br><br>';
unset($str, $time_start, $time_end, $time_used);
#####################################
$time_start = GetRunTime();
while(list($key, $val) = each($arr)){
$str .= $val;
$
time_end = GetRunTime();
$time_used = $time_end - $time_start;
echo 'その間の使用時間:'.round($time_used, 7).'(s)<br><br>';
unset($str, $key, $val, $time_start, $time_end, $time_used);
#####################################
$time_start = GetRunTime();
foreach($arr as $key => $val){
$str .= $val;
$
time_end = GetRunTime();
$time_used = $time_end - $time_start;
echo 'foreach の使用時間:'.round($time_used, 7).'(s)<br><br>';
#####################################
?>
テスト結果:
3 つのテスト結果の平均:
それぞれ for、while、foreach に対応します
0.1311650
0.1666853
0.1237440
テストを繰り返した結果、同じ配列を走査する場合、foreach が最も速く、while が最も遅いことがわかりました。 foreach は while よりも約 20% ~ 30% 高速です。次に、配列の添字を 500000 および 5000000 に増やしても、テスト結果は同じです。しかし、原理的な観点から見ると、foreach は (配列をコピーすることによって) 配列のコピーを操作しますが、while は配列の内部インデックスを移動することによって操作します。一般的に、while は foreach よりも高速であると考えられています。 foreach は最初に配列がコピーされる場所を配置し、while は内部ポインタを直接移動します) が、結果はまったく逆になります。その理由は、foreach が PHP の内部実装であるのに対し、while は一般的なループ構造であるためです。
したがって、一般的なアプリケーションでは、シンプルで効率的な foreach 形式を使用することを好みます。 PHP5 では、foreach はクラスの属性をトラバースすることもできます。