去除一个数组中的重复值,可以使用foreach方法,也可以使用array_unique方法,下面的代码两种方法都使用了。
测试$inttotal 大于10000时,$intrand取值100时,使用array_unique的效率要高于foreach循环判断,$intrand=10,两者执行时间一致。
因此,可以得出结论,当数组容量不大,大概在1000以内时,使用两者的执行效率差不多。
当数组容量比较大时(具体应该到什么值,我没有详细测试,感兴趣的可以确定一下这个值),随着$intrand的逐渐增大,array_unique的表现更好,我不使用$inttotal/$intrand这个比值,是因为,感觉并不是成比例变化,但是基本会遵循比值越大,array_unique表现越好。
综上所述,在过滤数组重复值的时候,建议使用array_unuique,数组不大的时候两者效率等同,而array_unique使用当然让你的代码一下子减了好几行,数组容量过大时,函数的表现更好,为什么不用呢?
http://www.bkjia.com/phpjc/752465.htmlwww.bkjia.comtruehttp://www.bkjia.com/phpjc/752465.htmltecharticle去除一个数组中的重复值,可以使用foreach方法,也可以使用array_unique方法,下面的代码两种方法都使用了。 ?php$arrf = array();$arrs = array();$...