>백엔드 개발 >PHP 튜토리얼 >대규모 배열 처리 시 PHP array_diff() 함수의 시간 초과 BUG 문제에 대한 자세한 설명

대규모 배열 처리 시 PHP array_diff() 함수의 시간 초과 BUG 문제에 대한 자세한 설명

巴扎黑
巴扎黑원래의
2017-05-23 18:02:152169검색

PHP 5.2.6 이상의 array_diff() 함수는 큰 배열을 처리할 때 매우 오랜 시간이 걸립니다. 이 버그는 이 문제가 해결되기 전이나 PHP 버전을 제어할 수 없는 경우에 공식적으로 확인되었습니다. 이 글에서 제공하는 메소드

cisa를 PHP 공식 BUG 페이지에 제출

코드는 다음과 같습니다.

<?php 
/** 
* 解决 php 5.2.6 以上版本 array_diff() 函数在处理 
* 大数组时的需要花费超长时间的问题 
* 
* 整理:http://www.CodeBit.cn 
* 来源:http://bugs.php.net/47643 
*/ 
function array_diff_fast($data1, $data2) { 
$data1 = array_flip($data1); 
$data2 = array_flip($data2); 
foreach($data2 as $hash => $key) { 
if (isset($data1[$hash])) unset($data1[$hash]); 
} 
return array_flip($data1); 
} 
?>


아이디어대로 ChinaUnix 포럼의 중재자인 hightman의 다시 작성된 메서드

의 코드는 다음과 같습니다.

<?php 
/** 
* 解决 php 5.2.6 以上版本 array_diff() 函数在处理大数组时的效率问题 
* 根据 ChinaUnix 论坛版主 hightman 思路写的方法 
* 
* 整理:http://www.CodeBit.cn 
* 参考:http://bbs.chinaunix.net/viewthread.php?tid=938096&rpid=6817036&ordertype=0&page=1#pid6817036 
*/ 
function array_diff_fast($firstArray, $secondArray) { 
// 转换第二个数组的键值关系 
$secondArray = array_flip($secondArray); 
// 循环第一个数组 
foreach($firstArray as $key => $value) { 
// 如果第二个数组中存在第一个数组的值 
if (isset($secondArray[$value])) { 
// 移除第一个数组中对应的元素 
unset($firstArray[$key]); 
} 
} 
return $firstArray; 
} 
?>

이 메서드는 두 번째 배열의 키와 값만 교환하며, 그래서 더 효율적입니다.
참고: PHP에 내장된 array_diff() 함수는 여러 배열을 처리할 수 있지만 이 기사에서 제공하는 방법은 두 배열의 비교만 처리합니다.

위 내용은 대규모 배열 처리 시 PHP array_diff() 함수의 시간 초과 BUG 문제에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.