Rumah >pembangunan bahagian belakang >tutorial php >Pertukaran nilai kunci tatasusunan PHP: panduan pemilihan algoritma dan faktor prestasi
Dalam PHP, terdapat banyak cara untuk melaksanakan pertukaran nilai kunci tatasusunan:
) kod> Fungsi:$new_array = array_flip($old_array);
array_flip()
函数:专为数组键值互换而设计,性能优异。
$new_array = []; foreach ($old_array as $key => $value) { $new_array[$value] = $key; }
自写循环:通过手动遍历数组来交换键和值。
$keys = array_keys($old_array); $values = array_values($old_array); $new_array = array_combine($values, $keys);
使用 array_combine()
和 array_values()
函数:将键和值分离到单独的数组中,然后使用 array_combine()
重新组合。
$old_array = ['foo' => 1, 'bar' => 2]; // 使用自写循环高效互换键值 $new_array = []; foreach ($old_array as $key => $value) { $new_array[$value] = $key; }
算法选择对性能有显著影响:
array_flip()
对于大型数组的性能最好,而自写循环对于小数组更为高效。array_combine()
$old_array = ['John' => 'Doe', 'Jane' => 'Smith']; // 使用 array_flip() 获得最佳性能 $new_array = array_flip($old_array);
Gunakan fungsi array_combine()
dan array_values()
:
array_combine( )
Kumpul semula. $old_array = [1 => 'foo', 2 => 'bar', 3 => 'baz']; // 使用 array_combine() 和 array_values() 保留键值相关性 $keys = array_keys($old_array); $values = array_values($old_array); $new_array = array_combine($values, $keys);Faktor yang mempengaruhi prestasi
Pemilihan algoritma mempunyai kesan yang ketara ke atas prestasi:
🎜🎜Saiz tatasusunan: 🎜array_flip()
berprestasi terbaik untuk tatasusunan yang besar, manakala tatasusunan ditulis sendiri tatasusunan adalah lebih cekap. 🎜🎜🎜Jenis Kunci: 🎜 Tatasusunan dengan kekunci rentetan menukar nilai kunci dengan lebih perlahan daripada tatasusunan dengan kekunci angka. 🎜🎜🎜Korelasi nilai kunci: 🎜Jika terdapat beberapa korelasi antara kunci dan nilai (contohnya, kunci ialah nilai berangka dan nilainya adalah rentetan), maka gelung tulisan sendiri atau array_combine( )
lebih berguna Sesuai. 🎜🎜🎜Kes praktikal🎜🎜🎜Kes 1: Tatasusunan kecil🎜🎜rrreee🎜🎜Kes 2: Susunan besar🎜🎜rrreee🎜🎜Kes 3: Nilai-nilai utama berkaitan🎜reeeAtas ialah kandungan terperinci Pertukaran nilai kunci tatasusunan PHP: panduan pemilihan algoritma dan faktor prestasi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!