교대 값이 있는 평면 배열을 최적으로 병합
성능이 중요한 상황에서는 동일한 크기의 두 평면 배열을 병합해야 할 수도 있습니다. 크기를 변경하고 해당 값을 번갈아 사용합니다. 어레이를 반복하는 간단한 루프를 통해 이를 달성할 수 있지만 잠재적인 성능 최적화를 위한 여지가 남습니다.
네이티브 솔루션
어레이를 효율적으로 병합하는 한 가지 방법은 미리 계산된 개수. 개선된 PHP 코드는 다음과 같습니다.
$count = count($a1); for ($i = 0; $i < $count; $i++) { $newArray[] = $a1[$i]; $newArray[] = $a2[$i]; }
벤치마크 비교
성능 차이를 입증하기 위해 원본 코드와 업데이트된 코드를 사용하여 벤치마크를 실행했습니다.
$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 $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++) // count() inside loop { $newArray[] = $a1[$i]; $newArray[] = $a2[$i]; } } echo round(microtime(TRUE) - $start, 2); # 0.85
결과에 따르면 count()를 사용하여 배열 크기를 미리 계산하면 속도가 눈에 띄게 향상됩니다. 반복적인 계산을 방지함으로써 최적화된 코드가 훨씬 더 빠르게 작동합니다.
위 내용은 PHP에서 두 개의 평면 배열을 대체 값으로 최적으로 병합하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!