PHP的array_diff()函数在处理大数组时的效率问题
程序员文章站
2022-07-07 08:18:22
cisa 提交到 php 官方 bug 页面上的方法 复制代码 代码如下:
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;
}
?>
此方法只交换了第二个数组的 key 和 value,所以效率更高。
注意:php 内置的 array_diff() 函数可以处理多个数组,而本文提供的方法只处理了两个数组的比较。
复制代码 代码如下:
<?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;
}
?>
此方法只交换了第二个数组的 key 和 value,所以效率更高。
注意:php 内置的 array_diff() 函数可以处理多个数组,而本文提供的方法只处理了两个数组的比较。
推荐阅读
-
PHP的array_diff()函数在处理大数组时的效率问题
-
WEB-js在函数传递对象数组数据时出现的传输不进去了问题
-
PHP的array_diff()函数在处理大数组时的效率问题_PHP教程
-
关于PHP fopen函数在windows系统上创建中文命名的文档时乱码的问题
-
PHP的array_diff()函数在处理大数组时的效率问题_php技巧
-
PHP的array_diff()函数在处理大数组时的效率问题_PHP
-
PHP的array_diff()函数在处理大数组时的效率问题_php技巧
-
php 求数组差集的自定义函数(效率优于array_diff函数)
-
PHP的array_diff()函数在处理大数组时的效率问题_PHP
-
serializearray PHP的array_diff函数在处理大数组时的效率问题