<?php
/*
* 解决 php 5.2.6 以上版本 array_diff() 函数在处理
* 大数组时的需要花费超长时间的问题
function array_diff_fast($data1, $data2) {
$data1 = array_flip($data1);
//$data2 = array_flip($data2);
foreach($data2 as $hash => $key) {
if (isset($data1[$key])) unset($data1[$key]);
}
return array_flip($data1);
}
$data1 = [1,2,3,4,5,6,7,8];
$data2 = [1,2,3,4,5,123];
//var_dump(array_diff($data1,$data2));//43ms
var_dump(array_diff_fast($data1,$data2));//6ms
?>
针对array_diff()的优化
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 针对 dispatch_once 的优化 dispatch_once 说明 先看这个 很多人写过类似的代码吧?di...