PHP两种去掉数组重复值的方法比较

2015-01-24信息快讯网

这篇文章主要介绍了PHP两种去掉数组重复值的方法比较,分别是foreach方法和array_unique方法,需要的朋友可以参考下

去除一个数组中的重复值,可以使用foreach方法,也可以使用array_unique方法,下面的代码两种方法都使用了。

<?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使用ob_start()实现图片存入变量的方法
php使用date和strtotime函数输出指定日期的方法
php获取url参数方法总结
PHP采用get获取url汉字出现乱码的解决方法
php数组保存文本与文本反编成数组实例
php一维二维数组键排序方法实例总结
php获取随机数组列表的方法
php合并数组中相同元素的方法
PHP获取数组中重复最多的元素的实现方法
php数组操作之键名比较与差集、交集赋值的方法
php中file_get_contents与curl性能比较分析
php实现的zip文件内容比较类
当前比较流行的两款PHP加密、解密工具Zend Guard和iconCube介绍
PHP中比较时间大小实例
php获取网页中图片、DIV内容的简单方法
PHP封装的一个支持HTML、JS、PHP重定向的多功能跳转函数
PHP mkdir()无写权限的问题解决方法
PHP中的多行字符串传递给JavaScript的两种方法
ThinkPHP模板引擎之导入资源文件方法详解
ThinkPHP CURD方法之field方法详解
ThinkPHP CURD方法之data方法详解
php判断数组元素中是否存在某个字符串的方法
PHP中多维数组的foreach遍历示例
PHP 如何获取二维数组中某个key的集合
PHP 二维数组根据某个字段排序的具体实现
php数组中包含中文的排序方法
php中curl、fsocket、file_get_content三个函数的使用比较
php代码审计比较有意思的例子
PHP中比较两个字符串找出第一个不同字符位置例子
php多维数组去掉重复值示例分享
php获得用户ip地址的比较不错的方法
php比较两个绝对时间的大小
©2014-2024 dbsqp.com