> 백엔드 개발 > PHP 튜토리얼 > colesafearray PHP 배열 순회(array_diff 구현)의 차이점에 대한 생각

colesafearray PHP 배열 순회(array_diff 구현)의 차이점에 대한 생각

WBOY
풀어 주다: 2016-07-29 08:37:29
원래의
1218명이 탐색했습니다.

function array_diff($array_1, $array_2) {
$diff = array();
foreach ($array_1 as $k => $v1) {
$flag = false
foreach( $array_2 as $v2) {
if ($flag = ($v1 == $v2)) {
break
}
}
If (!$flag) {
                                                                        그래서 알고리즘을 다시 생각하고 최적화했습니다.
function array_diff($array_1, $array_2) {
foreach ($array_1 as $key => $ item) {
if ( in_array ($ item, $ array_2, true)) {
unset ($ array_1 [$ key]) 🎜>} 음, 이번에는 원래 array_diff 함수만큼 빠릅니다. 하지만 더 최적화된 방법이 있을까요? ChinaUnix에 대한 기사(죄송합니다. 속였습니다)에서 PHP가 실제로 다음과 같이 작성할 수 있다는 것을 발견했습니다.
function array_diff($array_1, $array_2) {
$array_2 = array_flip($array_2)
foreach ($array_1 as $key => $item) {
if (isset($array_2[$item])) {
unset($array_1[$key])
}
}
return $array_1;
} 이 함수의 효율성은 원래 array_diff 함수보다 훨씬 빠릅니다. 이유를 조사해 보니 설명이 다음과 같습니다.
키가 HASH로 정리되어 있어서 검색 속도가 매우 빠릅니다.
값은 Key 정리에만 저장되고, 인덱스 자체는 없고, 검색할 때마다 순회합니다. . 요약
이것은 PHP 언어의 약간의 트릭이지만 배열 값을 순회하고 비교할 때 값을 비교해야 하는 경우 키를 사용하여 역순으로 하는 것이 실제로 일반적인 값 대 값 비교보다 훨씬 효율적입니다.
예를 들어 위의 함수 2는 in_array 함수를 호출해야 하며 함수 내에 있는지 확인하기 위해 반복해야 하며, 함수 3은 키가 배열에 존재하는지 여부만 확인합니다. 배열 키와 값의 다양한 조직적 인덱싱 방법과 결합하면 효율성이 상상 이상으로 높다는 것은 매우 이해할 수 있습니다.
첨부코드



코드 복사

코드는 다음과 같습니다


function microtime_float() {
    list($usec, $sec) = explode(" ", microtime());
    return ((float)$usec   (float)$sec);
}
함수 array_diff2($array_1, $array_2) {
    $diff = array();
    foreach ($array_1 as $k => $v1) {
        $flag = false;
        foreach ($array_2 as $v2) {
           if ($flag = ($v1 == $v2)) {
               break;
            }
        }
        if (!$flag) {
           $diff[$k] = $v1;
        }
    }
    return $diff;
}
함수 배열_diff3($array_1, $array_2) {
    foreach($array_1 as $key => $item) {
        if (in_array($item, $array_2, true)) {
            unset($array_1[$key]);
        }
    }
    return $array_1;
}
함수 array_diff4($array_1, $array_2) {
    $array_2 = array_flip($array_2);
    foreach ($array_1 as $key => $item) {
        if (isset($array_2[$item])) {
            unset($array_1[$key]);
        }
     }
    return $array_1;
}
//////////////////////////////
for($i = 0, $ary_1 = 배열();  $i <  $i ) {
    $ary_1[] = rand(100, 999);
}
for($i = 0, $ary_2 = array(); $i < 5000; $i ) {
    $ary_2[] = rand(100, 999);
}
header("콘텐츠 유형: text/plain;charset=utf-8");
$time_start = microtime_float();
array_diff($ary_1, $ary_2);
에코 '函数 array_diff 运行' . (microtime_float() - $time_start). " 秒n";
$time_start = microtime_float();
array_diff2($ary_1, $ary_2);
에코 '函数 array_diff2 运行' . (microtime_float() - $time_start). " 秒n";
$time_start = microtime_float();
array_diff3($ary_1, $ary_2);
에코 '函数 array_diff3 运行' . (microtime_float() - $time_start). " 秒n";
$time_start = microtime_float();
array_diff4($ary_1, $ary_2);
에코 "函数 array_diff4 运行" . (microtime_float() - $time_start). " 秒n";
?>


以上就介绍了colesafearray 深思 PHP 数组遍历的差异(array_diff 的实现),包括了colesafearray방식의 内容, 希望对PHP教程有兴趣的朋友有所帮助。

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿