生活随笔
收集整理的這篇文章主要介紹了
php代码优化 -- array_walk 和 foreach, for 的效率的比较
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
<?
php
/*** array_walk 和 foreach, for 的效率的比較。* 我們要測(cè)試的是foreach, for, 和 array_walk的效率的問(wèn)題。 *///產(chǎn)生一個(gè)10000的一個(gè)數(shù)組。
$max =
10000;
$test_arr = range(
0, $max);
$temp;
//我們分別用三種方法測(cè)試求這些數(shù)加上1的值的時(shí)間。// for 的方法
$t1 = microtime(
true);
for ($i =
0; $i < $max; $i++
) {$temp = $temp +
1;
}
$t2 = microtime(
true);
$t = $t2 -
$t1;
echo "就使用for, 沒(méi)有對(duì)數(shù)組操作 花費(fèi): {$t}\n";$t1 = microtime(
true);
for ($i =
0; $i < $max; $i++
) {$test_arr[$i] = $test_arr[$i] +
1;
}
$t2 = microtime(
true);
$t = $t2 -
$t1;
echo "使用for 并且直接對(duì)數(shù)組進(jìn)行了操作 花費(fèi): {$t}\n";$t1 = microtime(
true);
for ($i =
0; $i < $max; $i++
) {addOne($test_arr[$i]);
}
$t2 = microtime(
true);
$t = $t2 -
$t1;
echo "使用for 調(diào)用函數(shù)對(duì)數(shù)組操作 花費(fèi) : {$t}\n";$t1 = microtime(
true);
foreach ($test_arr
as $k => &
$v) {$temp = $temp +
1;
}
$t2 = microtime(
true);
$t = $t2 -
$t1;
echo "使用 foreach 沒(méi)有對(duì)數(shù)組操作 花費(fèi) : {$t}\n";$t1 = microtime(
true);
foreach ($test_arr
as $k => &
$v) {$v = $v +
1;
}
$t2 = microtime(
true);
$t = $t2 -
$t1;
echo "使用 foreach 直接對(duì)數(shù)組操作 : {$t}\n";$t1 = microtime(
true);
foreach ($test_arr
as $k => &
$v) {addOne($v);
}
$t2 = microtime(
true);
$t = $t2 -
$t1;
echo "使用 foreach 調(diào)用函數(shù)對(duì)數(shù)組操作 : {$t}\n";$t1 = microtime(
true);
array_walk($test_arr, 'addOne');
$t2 = microtime(
true);
$t = $t2 -
$t1;
echo "使用 array_walk 花費(fèi) : {$t}\n";function addOne(&
$item) {$item = $item +
1;
} 執(zhí)行的結(jié)果:
就使用for, 沒(méi)有對(duì)數(shù)組操作 花費(fèi): 0.15388584136963
使用 foreach 沒(méi)有對(duì)數(shù)組操作 花費(fèi) : 0.076934814453125
使用for 并且直接對(duì)數(shù)組進(jìn)行了操作 花費(fèi): 0.14769005775452
使用 foreach 直接對(duì)數(shù)組操作 : 0.076115131378174
使用for 調(diào)用函數(shù)對(duì)數(shù)組操作 花費(fèi) : 0.32393312454224
使用 foreach 調(diào)用函數(shù)對(duì)數(shù)組操作 : 0.25716996192932
使用 array_walk 花費(fèi) : 0.17966890335083
在對(duì)10000個(gè)數(shù)的操作過(guò)程中,這個(gè)實(shí)驗(yàn)我們可以得出這樣的結(jié)論:
foreach 的效率要比f(wàn)or 高很多,也許有很大的一個(gè)原因是for 要進(jìn)行很多次條件判斷。所以以后能用foreach的地方就用foreach,可以提高1倍的效率。
如果循環(huán)內(nèi)要調(diào)用函數(shù),用array_walk? 最好,它的效率要比f(wàn)or 高出1倍,要比f(wàn)oreach高出43%的效率。?
還有一個(gè)提示就是如果你這個(gè)程序?qū)π实囊笫呛芨叩?#xff0c;那不要在很深的循環(huán)中調(diào)用函數(shù),要調(diào)用函數(shù)也要用array_walk,最好的直接把代碼寫(xiě)在循環(huán)里面。
本文轉(zhuǎn)自TBHacker博客園博客,原文鏈接:http://www.cnblogs.com/jiqing9006/p/4094148.html,如需轉(zhuǎn)載請(qǐng)自行聯(lián)系原作者
總結(jié)
以上是生活随笔為你收集整理的php代码优化 -- array_walk 和 foreach, for 的效率的比较的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。