PHP遍歷數(shù)組的三種方法及效率對比分析
本文實例分析了PHP遍歷數(shù)組的三種方法及效率對比。分享給大家供大家參考。具體分析如下:
今天有個朋友問我一個問題php遍歷數(shù)組的方法,告訴她了幾個。順便寫個文章總結下,如果總結不全還請朋友們指出
第一、foreach()
foreach()是一個用來遍歷數(shù)組中數(shù)據的最簡單有效的方法。
<?php $urls= array('aaa','bbb','ccc','ddd'); foreach ($urls as $url){ echo "This Site url is $url! <br />"; } ?>
顯示結果:
This Site url is aaa This Site url is bbb This Site url is ccc This Site url is ddd
第二、while() 和 list(),each()配合使用。
<?php $urls= array('aaa','bbb','ccc','ddd'); while(list($key,$val)= each($urls)) { echo "This Site url is $val.<br />"; } ?>
顯示結果:
This Site url is aaa This Site url is bbb This Site url is ccc This Site url is ddd
第三、for()運用for遍歷數(shù)組
<?php $urls= array('aaa','bbb','ccc','ddd'); for ($i= 0;$i< count($urls); $i++){ $str= $urls[$i]; echo "This Site url is $str.<br />"; } ?>
顯示結果:
This Site url is aaa This Site url is bbb This Site url is ccc This Site url is ddd
有時候有人也在問這幾種遍歷數(shù)組的方法哪個更快捷些呢,下面做個簡單的測試就明白了
下面來測試三種遍歷數(shù)組的速度
一般情況下,遍歷一個數(shù)組有三種方法,for、while、foreach。其中最簡單方便的是foreach。下面先讓我們來測試一下共同遍歷一個有50000個下標的一維數(shù)組所耗的時間。
<?php $arr= array(); for($i= 0; $i< 50000; $i++){ $arr[]= $i*rand(1000,9999); } function 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 'Used time of for:'.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 'Used time of while:'.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 'Used time of foreach:'.round($time_used, 7).'(s)<br /><br />'; ?>
測試結果:
Used time of for:0.0228429(s) Used time of while:0.0544658(s) Used time of foreach:0.0085628(s)
經過反復多次測試,結果表明,對于遍歷同樣一個數(shù)組,foreach速度最快,最慢的則是while。從原理上來看,foreach是對數(shù)組副本進行操作(通過拷貝數(shù)組),而while則通過移動數(shù)組內部指標進行操作,一般邏輯下認為,while應該比foreach快(因為foreach在開始執(zhí)行的時候首先把數(shù)組復制進去,而while直接移動內部指標。),但結果剛剛相反。原因應該是,foreach是PHP內部實現(xiàn),而while是通用的循環(huán)結構。所以,在通常應用中foreach簡單,而且效率高。在PHP5下,foreach還可以遍歷類的屬性。
希望本文所述對大家的php程序設計有所幫助。
- php中使用key,value,current,next和prev函數(shù)遍歷數(shù)組的方法
- PHP數(shù)組遍歷知識匯總(包含遍歷方法、數(shù)組指針操作函數(shù)、數(shù)組遍歷測速)
- PHP遍歷數(shù)組的方法匯總
- PHP 數(shù)組遍歷方法大全(foreach,list,each)
- PHP循環(huán)遍歷數(shù)組的3種方法list()、each()和while總結
- PHP中使用foreach()遍歷二維數(shù)組的簡單實例
- PHP遍歷二維數(shù)組的代碼
- 深思 PHP 數(shù)組遍歷的差異(array_diff 的實現(xiàn))
- php數(shù)組聲明、遍歷、數(shù)組全局變量使用小結
- PHP中使用數(shù)組指針函數(shù)操作數(shù)組示例
- php數(shù)組指針操作詳解
- PHP 數(shù)組操作詳解【遍歷、指針、函數(shù)等】
相關文章
Windows2003 下 MySQL 數(shù)據庫每天自動備份
Windows2003 下 MySQL 數(shù)據庫每天自動備份...2006-12-12