|
在循環(huán)里進(jìn)行的是數(shù)組“讀”操作,則foreach比while快:
復(fù)制代碼 代碼如下:
foreach ($array as $value) {
echo $value;
}
while (list($key) = each($array)) {
echo $array[$key];
}
在循環(huán)里進(jìn)行的是數(shù)組“寫(xiě)”操作,則while比f(wàn)oreach快:
復(fù)制代碼 代碼如下:
foreach ($array as $key => $value) {
echo $array[$key] = $value . '...';
}
while (list($key) = each($array)) {
$array[$key] = $array[$key] . '...';
}
總結(jié):通常認(rèn)為,foreach涉及到值復(fù)制,一定會(huì)比while慢,但實(shí)際上,如果僅僅是在循環(huán)里進(jìn)行數(shù)組的讀操作,那么foreach是很
快的,這是因?yàn)?a href=/itjie/phpjishu/ target=_blank class=infotextkey>php采用的復(fù)制機(jī)制是“引用計(jì)數(shù),寫(xiě)時(shí)復(fù)制”,也就是說(shuō),即便在php里復(fù)制一個(gè)變量,最初的形式從根本上說(shuō)其實(shí)
仍然是引用的形式,只有當(dāng)變量的內(nèi)容發(fā)生變化時(shí),才會(huì)出現(xiàn)真正的復(fù)制,之所以這么做是出于節(jié)省內(nèi)存消耗得目的,同時(shí)也提升了
復(fù)制的效率。這樣看來(lái),foreach的高效讀操作就不難理解了。另外,既然foreach不適合處理數(shù)組寫(xiě)操作,那么我們可以得出一個(gè)結(jié)
論,多數(shù)情況下,類似foreach ($array as $key => $value)形式的做數(shù)組寫(xiě)操作得代碼都應(yīng)該被替換成while (list($key) =
each($array))。這些技巧產(chǎn)生的速度差異在小項(xiàng)目里可能并不明顯,但是在類似框架這樣的大項(xiàng)目中,一次請(qǐng)求動(dòng)輒便會(huì)涉及到幾
百幾千幾萬(wàn)次數(shù)組循環(huán)操作,差異就會(huì)明顯放大。
php技術(shù):php foreach、while性能比較,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。