Mencari Tatasusunan Berbilang Dimensi untuk Nilai Kekunci Padanan
Apabila merentasi tatasusunan berbilang dimensi untuk mencari kunci tertentu dan nilai sepadannya, perkara biasa ditemui isu rekursi. Pertimbangkan kaedah sampel berikut:
<code class="php">private function find($needle, $haystack) { foreach ($haystack as $name => $file) { if ($needle == $name) { return $file; } else if(is_array($file)) { //is folder return $this->find($needle, $file); //file is the new haystack } } return "did not find"; }</code>
Kaedah ini bertujuan untuk mencari kunci dalam tatasusunan bersekutu dan mengembalikan nilai yang dikaitkan dengannya. Walau bagaimanapun, terdapat potensi isu dengan pendekatan rekursifnya.
Untuk menyelesaikan masalah ini, penyelesaian yang lebih moden dan cekap boleh digunakan menggunakan ciri PHP yang lebih baharu:
<code class="php">function recursiveFind(array $haystack, $needle) { $iterator = new RecursiveArrayIterator($haystack); $recursive = new RecursiveIteratorIterator( $iterator, RecursiveIteratorIterator::SELF_FIRST ); foreach ($recursive as $key => $value) { if ($key === $needle) { return $value; } } }</code>
Kaedah ini menggunakan rekursi dan iterator untuk melintasi tatasusunan dengan cekap dan mencari kekunci padanan pertama.
Sebagai alternatif, jika anda ingin mengulangi semua perlawanan dan bukannya yang pertama sahaja, anda boleh menggunakan penjana PHP 5.6:
<code class="php">function recursiveFind(array $haystack, $needle) { $iterator = new RecursiveArrayIterator($haystack); $recursive = new RecursiveIteratorIterator( $iterator, RecursiveIteratorIterator::SELF_FIRST ); foreach ($recursive as $key => $value) { if ($key === $needle) { yield $value; } } } // Usage foreach (recursiveFind($haystack, $needle) as $value) { // Use `$value` here }</code>
Dengan pendekatan ini, anda boleh mengulang secara elegan semua nilai padanan dalam tatasusunan.
Atas ialah kandungan terperinci Bagaimana untuk Mencari Nilai Utama dalam Tatasusunan Multidimensi dengan Cekap dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!