过滤掉PHP数组中的重复值的实现代码
作者:bea
代码如下: <?php $arrF = array(); $arrS = array(); $intTotal = 100; $intRand = 10; for($i=0; $i < $intTotal; $i++) { $arrF[] = rand(1, $intRand); $arrS[] = rand(1, $intRand); } $arrT = array_merge($arrF, $arrS); $arrRF = arra
代码如下:
<?php
$arrF = array();
$arrS = array();
$intTotal = 100;
$intRand = 10;
for($i=0; $i < $intTotal; $i++)
{
$arrF[] = rand(1, $intRand);
$arrS[] = rand(1, $intRand);
}
$arrT = array_merge($arrF, $arrS);
$arrRF = array();
$intStart = time();
foreach($arrT as $v)
{
if(in_array($v, $arrRF))
{
continue;
}
else
{
$arrRF[] = $v;
}
}
$intEnd = time();
$intTime = $intEnd-$intStart;
echo "With Continue,Spend time:$intTime<br/>";
$intStart1 = time();
$arrRS = array_unique($arrT);
$intEnd2 = time();
$intTime2 = $intEnd2-$intStart1;
echo "With array_unique function,Spend time:($intTime2)";
echo "<pre>";
print_r($arrT);
print_r($arrRF);
print_r($arrRS);
echo "</pre>";
?>
在$intTotal比较小的情况下,比如说1000以内,$intRand的取值基本不影响结果,两者执行的时间都差不多。
测试$intTotal 大于10000时,$intRand取值100时,使用array_unique的效率要高于foreach循环判断,$intRand=10,两者执行时间一致。
因此,可以得出结论,当数组容量不大,大概在1000以内时,使用两者的执行效率差不多。
当数组容量比较大时(具体应该到什么值,我没有详细测试,感兴趣的可以确定一下这个值),随着$intRand的逐渐增大,array_unique的表现更好,我不使用$intTotal/$intRand这个比值,是因为,感觉并不是成比例变化,但是基本会遵循比值越大,array_unique表现越好。
综上所述,在过滤数组重复值的时候,建议使用array_unuique,数组不大的时候两者效率等同,而array_unique使用当然让你的代码一下子减了好几行,数组容量过大时,函数的表现更好,为什么不用呢?
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- php文档更新介绍
- php 数据库字段复用的基本原理与示例
- PHP查询MySQL大量数据的时候内存占用分析
- PHP性能优化 产生高度优化代码
- PHP多个版本的分析解释
- QQ登录 PHP OAuth示例代码
- 模板引擎正则表达式调试小技巧
- php中批量替换文件名的实现代码
- 关于php连接mssql:pdo odbc sql server
- PHP mcrypt可逆加密算法分析
- PHP中date()日期函数有关参数整理
- php URL验证正则表达式
- PHP中static关键字原理的学习研究分析
- 在WAMP环境下搭建ZendDebugger php调试工具的方法
- 无法载入 mcrypt 扩展,请检查 PHP 配置终极解决方案
- PHP通过iconv将字符串从GBK转换为UTF8字符集
- PHP中英混合字符串截取函数代码
- PHP操作数组的一些函数整理介绍
- 如何突破PHP程序员的技术瓶颈分析