(PHP 4, PHP 5, PHP 7)
foreach yapısı diziler üzerinde yineleme yapmayı kolaylaştırmaktadır. foreach yalnızca diziler ve nesneler için kullanılabilir; farklı veri türünde veya ilklendirilmemiş bir değişken ile kullanmak istediğinizde hata verir. İki sözdizimi mevcuttur:
foreach (dizi_ifadesi as $değer) deyim foreach (dizi_ifadesi as $isim => $değer) deyim
İlk sözdizimi dizi_ifadesi ile belirtilen dizinin üzerinde döngü oluşturur. Her yinelemede, sırası gelen elemanın değeri $değer değişkenine atanır ve dizi göstericisi bir arttırılır (böylece bir sonraki yinelemede dizinin bir sonraki elemanına bakılması sağlanmış olur).
İkinci yöntem de aynı şeyi yapar, ek olarak her yinelemede sırası gelen elemanın anahtarı $isim değişkenine atanır.
PHP 5'den itibaren, nesneleri yinelemek mümkün olmuştur.
Bilginize:
foreach ilk çalışmaya başladığında, dizi göstericisi özdevinimli olarak ilk elemanı gösterecek biçimde sıfırlanır. Bu sebeple, foreach deyiminden önce reset() işlevini çalıştırmanıza gerek yoktur.
foreach dahili bir dizi göstericisi ile çalışması nedeniyle bunun döngü içinde değiştirilmesi beklenmedik sonuçlara yol açabilir.
$değer değişkeninin önüne & koyarak dizi elemanları üzerinde kolayca değişiklik yapılabilir. Böylece değer gönderimli hale gelir.
<?php
$dizi = array(1, 2, 3, 4);
foreach ($dizi as &$değer) {
$değer = $değer * 2;
}
// $dizi artık array(2, 4, 6, 8) olmuştur
unset($değer); // son eleman da işlendiğine göre gönderimi kaldıralım
?>
$değer değişkeninin gönderimli hale getirilebilmesi, sadece yinelenen dizi gönderimli (örn, bir değişkene) olabiliyorsa mümkündür, yani aşağıdaki kod çalışmaz:
<?php
foreach (array(1, 2, 3, 4) as &$value) {
$value = $value * 2;
}
?>
$değer gönderim için kullanıldığından foreach döngüsünün sonunda son dizi elemanına gönderimli olarak kalır, bu bakımdan döngünün sonunda bu gönderimin unset() işlevi kullanılarak kaldırılması önerilir.
Bilginize:
foreach, hata iletilerinin '@' kullanılarak gözardı edilmesi özelliğini desteklemez.
Aşağıdaki iki döngünün aynı işi yaptığını farkedeceksiniz:
<?php
$dizi = array("bir", "iki", "üç");
reset($dizi);
while (list(, $değer) = each($dizi)) {
echo "Değer: $değer<br />\n";
}
foreach ($dizi as $değer) {
echo "Değer: $değer<br />\n";
}
?>
Aşağıdakiler de işlevsel olarak aynıdır:
<?php
$dizi = array("bir", "iki", "üç");
reset($dizi);
while (list($isim, $değer) = each($dizi)) {
echo "Anahtar: $isim; Değer: $değer<br />\n";
}
foreach ($dizi as $isim => $değer) {
echo "Anahtar: $isim; Değer: $değer<br />\n";
}
?>
Değişik kullanımlara örnekler:
<?php
/* foreach örneği 1: yalnızca değer */
$a = array(1, 2, 3, 17);
foreach ($a as $v) {
echo "\$a değişkeninin şu anki değeri: $v.\n";
}
/* foreach örneği 2: değer (örnek olması için anahtar
* ile birlikte yazdırılmıştır) */
$a = array(1, 2, 3, 17);
$i = 0; /* yalnızca örnekleme için */
foreach ($a as $v) {
echo "\$a[$i] => $v.\n";
$i++;
}
/* foreach örneği 3: anahtar ve değer */
$a = array(
"bir" => 1,
"iki" => 2,
"üç" => 3,
"on yedi" => 17
);
foreach ($a as $k => $v) {
echo "\$a[$k] => $v.\n";
}
/* foreach örneği 4: çok boyutlu diziler */
$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 örneği 5: devingen diziler */
foreach (array(1, 2, 3, 4, 5) as $v) {
echo "$v\n";
}
?>
(PHP 5 >= 5.5.0, PHP 7)
PHP 5.5 ile yeni bir yetenek eklendi. Dizi dizileri üzerinde döngü oluşturmak ve list() işlevini değer olarak kullanmak suretiyle içteki diziyi döngü değişkenlerine atayarak onu da açmak artık mümkündür.
Örneğin:
<?php
$dizi = [
[1, 2],
[3, 4],
];
foreach ($dizi as list($a, $b)) {
// $a içteki dizinin ilk elemanını,
// $b ikinci elemanını içerecektir.
echo "A: $a; B: $b\n";
}
?>
Yukarıdaki örneğin çıktısı:
A: 1; B: 2 A: 3; B: 4
İçteki dizinin gerekmeyen elemanlarını list() içinde içermeyebilirsiniz:
<?php
$dizi = [
[1, 2],
[3, 4],
];
foreach ($dizi as list($a)) {
// Burada artık $b yok.
echo "$a\n";
}
?>
Yukarıdaki örneğin çıktısı:
1 3
list() için yeterli sayıda dizi elemanı yoksa bir uyarı üretilir.:
<?php
$dizi = [
[1, 2],
[3, 4],
];
foreach ($dizi as list($a, $b, $c)) {
echo "A: $a; B: $b; C: $c\n";
}
?>
Yukarıdaki örneğin çıktısı:
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: