我爱学习网首页 | 设为首页 | 收藏本站 | 网站地图 您好,欢迎光临我爱学习网
我爱学习网

当前位置:首页 > 编程开发 > php > php入门教程 >

php去除数组重复值的两种方法及效率比较

时间:2014-06-30 22:44 来源:我爱学习网 | 作者:我爱学习网 | 本文已影响
php去除一个数组中的重复值,可以使用foreach方法,也可以使用array_unique方法,下面程序为您演示了两种去除数组重复方法及执行效率。

<?php
$arrF = array();
$arrS = array();
$intTotal = 1000;
$intRand = 10000;//数组元素值
//生成随机数组
for($i=0; $i < $intTotal; $i++){
	$arrF[] = rand(1,$intRand);
	$arrS[] = rand(1,$intRand);
}

$arrT = array_merge($arrF, $arrS);//把两个数组合并为一个数组
$arrRF = array();
$intStart = microtime_float();
//通过foreach循环去除重复数组
foreach($arrT as $v){
	if(in_array($v, $arrRF)){
		continue;
	}else{
		$arrRF[] = $v;
	}
}
$intEnd = microtime_float();
$intTime = $intEnd-$intStart;//去重复所需时间
echo "通过foreach循环去除重复所需时间:$intTime<br/>";

$intStart1 =microtime_float();
$arrRS = array_unique($arrT);
$intEnd2 = microtime_float();
$intTime2 = $intEnd2-$intStart1;
echo "通过array_unique函数去除数组重复执行时间:($intTime2)";
echo "<pre>";
print_r($arrT);//原始数组
print_r($arrRF);//通过foreach去除重复后的数组
print_r($arrRS);//通过array_unique函数去除数组重复后的数组
echo "</pre>";
//取当前时间戳并精确到毫秒
function microtime_float(){
   list($usec, $sec) = explode(" ", microtime());
   return ((float)$usec + (float)$sec);
}
?>

通过上述比较,当$intTotal比较小的情况下,比如说1000以内,$intRand的取值基本不影响结果,两者执行的时间都差不多
当数组容量不大,大概在1000以内时,使用两者的执行效率差不多。
当数组容量比较大时(具体应该到什么值,我没有详细测试,感兴趣的可以确定一下这个值),随着$intRand的逐渐增大,array_unique的表现更好,过滤重复所需的时间更短。
综上所述,在过滤数组重复值的时候,建议使用array_unuique,数组不大的时候两者效率等同,而array_unique使用当然让你的代码一下子减了好几行,数组容量过大时,函数的表现更好,为什么不用呢?
(责任编辑:我爱学习网)


分享到: 更多