Selang-seli Cantumkan Dua Tatasusunan dalam Fesyen Dioptimumkan
Dalam bidang pengaturcaraan, menggabungkan dua tatasusunan dengan cekap adalah tugas biasa. Walaupun penggabungan adalah mudah, mungkin terdapat keadaan di mana anda memerlukan penggabungan berselang-seli, menjalin nilai daripada kedua-dua tatasusunan. Walaupun penyelesaian gelung naif tersedia, ia boleh menjadi suboptimum dari sudut prestasi.
Untuk aplikasi sensitif masa yang memerlukan operasi penggabungan yang kerap, pendekatan yang lebih cekap adalah wajar. PHP menyediakan penyelesaian terbina dalam yang mencapai pengoptimuman ini:
$count = count($a1); for ($i = 0; $i < $count; $i++) { $newArray[] = $a1[$i]; $newArray[] = $b1[$i]; }
Kaedah ini pra-mengira saiz tatasusunan yang terhasil dan memberikan nilai secara bergilir-gilir daripada kedua-dua tatasusunan input, menghasilkan operasi gabungan yang dioptimumkan. Penandaarasan menunjukkan bahawa teknik ini mengatasi pendekatan gelung naif, terutamanya apabila melaksanakan beribu-ribu operasi gabungan:
// Pre-counting array size $a1 = array(0, 1, 2); $a2 = array(3, 4, 5); $start = microtime(TRUE); for ($t = 0; $t < 100000; $t++) { $newArray = array(); $count = count($a1); for ($i = 0; $i < $count; $i++) { $newArray[] = $a1[$i]; $newArray[] = $a2[$i]; } } echo round(microtime(TRUE) - $start, 2); // 0.6 // Without pre-counting $a1 = array(0, 1, 2); $a2 = array(3, 4, 5); $start = microtime(TRUE); for ($t = 0; $t < 100000; $t++) { $newArray = array(); for ($i = 0; $i < count($a1); $i++) { $newArray[] = $a1[$i]; $newArray[] = $a2[$i]; } } echo round(microtime(TRUE) - $start, 2); // 0.85
Kesimpulannya, kaedah terbina dalam dengan saiz tatasusunan pra-kira menawarkan kelebihan prestasi yang ketara untuk masa- aplikasi sensitif yang memerlukan operasi penggabungan tatasusunan yang kerap.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengoptimumkan Penggabungan Array Bergantian dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!