PHP数组重复值过滤,到底是选择foreach 还是 array_unique?

1 <?php
2  $arrF = array();
3  $arrS = array();
4  $intTotal = 100000;
5 $intRand = 10;
6 for($i=0;$i < $intTotal;$i++)
7 {
8 $arrF[] = rand(1,$intRand);
9 $arrS[] = rand(1,$intRand);
10 }
11 $arrT = array_merge($arrF,$arrS);
12 $arrRF = array();
13 $intStart = time();
14 foreach($arrT as $v)
15 {
16 if(in_array($v,$arrRF)){
17 continue;
18 }else{
19 $arrRF[] = $v;
20 }
21 }
22 $intEnd = time();
23 $intTime = $intEnd-$intStart;
24 echo "With Continue,Spend time:$intTime<br/>";
25 $intStart1 = time();
26 $arrRS = array_unique($arrT);
27 $intEnd2 = time();
28 $intTime2 = $intEnd2-$intStart1;
29 echo "With array_unique function,Spend time:($intTime2)";
30 echo "<pre>";
31 print_r($arrT);
32 print_r($arrRF);
33 print_r($arrRS);
34 echo "</pre>";
35 ?>
36

 


  在$intTotal比较小的情况下,比如说1000以内,$intRand的取值基本不影响结果,两者执行的时间都差不多。
  测试$intTotal 大于10000时,$intRand取值100时,使用array_unique的效率要高于foreach循环判断,$intRand=10,两者执行时间一致。

 

 

      因此,可以得出结论,当数组容量不大,大概在1000以内时,使用两者的执行效率差不多。

      当数组容量比较大时(具体应该到什么值,我没有详细测试,感兴趣的可以确定一下这个值),随着$intRand的逐渐增大,array_unique的表现更好,我不使用$intTotal/$intRand这个比值,是因为,感觉并不是成比例变化,但是基本会遵循比值越大,array_unique表现越好。

  遵上所述,在过滤数组重复值的时候,建议使用array_unuique,数组不大的时候两者效率等同,而array_unique使用当然让你的代码一下子减了好几行,数组容量过大时,函数的表现更好,为什么不用呢?

posted on 2010-11-17 10:05  陆西星  阅读(2326)  评论(0编辑  收藏  举报

导航