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