foreach
(PHP 4, PHP 5, PHP 7, PHP 8)
foreach
語法結構提供了遍歷陣列的簡單方式。foreach
僅能夠應用於陣列和對象,如果嘗試應用於其他數據型別的變數,或者未初始化的變數將發出錯誤資訊。有兩種語法:
foreach (iterable_expression as $value) statement foreach (iterable_expression as $key => $value) statement
第一種格式遍歷給定的 iterable_expression
迭代器。每次循環中,目前單元的值被賦給 $value
。
第二種格式做同樣的事,只除了目前單元的鍵名也會在每次循環中被賦給變數
$key
。
注意 foreach
不會修改類似 current()
和 key() 函式所使用的陣列內部指針。
還能夠自定義遍歷對像。
可以很容易地通過在 $value
之前加上
& 來修改陣列的元素。此方法將以引用賦值而不是拷貝一個值。
<?php
$arr = array(1, 2, 3, 4);
foreach ($arr as &$value) {
$value = $value * 2;
}
// 現在 $arr 是 array(2, 4, 6, 8)
unset($value); // 最後取消掉引用
?>
陣列最後一個元素的 $value
引用在
foreach
循環之後仍會保留。建議使用
unset() 來將其銷燬。
否則你會遇到下面的情況:
<?php
$arr = array(1, 2, 3, 4);
foreach ($arr as &$value) {
$value = $value * 2;
}
// 現在 $arr 是 array(2, 4, 6, 8)
// 未使用 unset($value) 時,$value 仍然引用到最後一項 $arr[3]
foreach ($arr as $key => $value) {
// $arr[3] 會被 $arr 的每一項值更新掉…
echo "{$key} => {$value} ";
print_r($arr);
}
// 直到最終倒數第二個值被複制到最後一個值
// output:
// 0 => 2 Array ( [0] => 2, [1] => 4, [2] => 6, [3] => 2 )
// 1 => 4 Array ( [0] => 2, [1] => 4, [2] => 6, [3] => 4 )
// 2 => 6 Array ( [0] => 2, [1] => 4, [2] => 6, [3] => 6 )
// 3 => 6 Array ( [0] => 2, [1] => 4, [2] => 6, [3] => 6 )
?>
可以通過引用來遍歷陣列常量的值:
<?php
foreach (array(1, 2, 3, 4) as &$value) {
$value = $value * 2;
}
?>
注意:
foreach
不支援用 「@
」 來抑制錯誤資訊的能力。
示範用法的更多例子:
<?php
/* foreach 示例 1:僅 value */
$a = array(1, 2, 3, 17);
foreach ($a as $v) {
echo "Current value of \$a: $v.\n";
}
/* foreach 示例 2:value (列印手動訪問的符號以供說明) */
$a = array(1, 2, 3, 17);
$i = 0; /* 僅供說明 */
foreach ($a as $v) {
echo "\$a[$i] => $v.\n";
$i++;
}
/* foreach 示例 3:key 和 value */
$a = array(
"one" => 1,
"two" => 2,
"three" => 3,
"seventeen" => 17
);
foreach ($a as $k => $v) {
echo "\$a[$k] => $v.\n";
}
/* foreach 示例 4:多維陣列 */
$a = array();
$a[0][0] = "a";
$a[0][1] = "b";
$a[1][0] = "y";
$a[1][1] = "z";
foreach ($a as $v1) {
foreach ($v1 as $v2) {
echo "$v2\n";
}
}
/* foreach 示例 5:動態陣列 */
foreach (array(1, 2, 3, 4, 5) as $v) {
echo "$v\n";
}
?>
用 list() 給巢狀的陣列解包
(PHP 5 >= 5.5.0, PHP 7, PHP 8)
可以遍歷一個陣列的陣列並且把巢狀的陣列解包到循環變數中,只需將 list() 作為值提供。
例如:
<?php
$array = [
[1, 2],
[3, 4],
];
foreach ($array as list($a, $b)) {
// $a 包含巢狀陣列的第一個元素,
// $b 包含巢狀陣列的第二個元素。
echo "A: $a; B: $b\n";
}
?>
以上例程會輸出:
A: 1; B: 2 A: 3; B: 4
list() 中的單元可以少於巢狀陣列的,此時多出來的陣列單元將被忽略:
<?php
$array = [
[1, 2],
[3, 4],
];
foreach ($array as list($a)) {
// 注意這裡沒有 $b。
echo "$a\n";
}
?>
以上例程會輸出:
1 3
如果 list() 中列出的單元多於巢狀陣列則會發出一條訊息級別的錯誤資訊:
<?php
$array = [
[1, 2],
[3, 4],
];
foreach ($array as list($a, $b, $c)) {
echo "A: $a; B: $b; C: $c\n";
}
?>
以上例程會輸出:
Notice: Undefined offset: 2 in example.php on line 7 A: 1; B: 2; C: Notice: Undefined offset: 2 in example.php on line 7 A: 3; B: 4; C: