中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

PHP兩種去掉數組重復值的方法比較

去除一個數組中的重復值,可以使用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的取值基本不影響結果,兩者執(zhí)行的時間都差不多。

測試$intTotal 大于10000時,$intRand取值100時,使用array_unique的效率要高于foreach循環(huán)判斷,$intRand=10,兩者執(zhí)行時間一致。

因此,可以得出結論,當數組容量不大,大概在1000以內時,使用兩者的執(zhí)行效率差不多。

當數組容量比較大時(具體應該到什么值,我沒有詳細測試,感興趣的可以確定一下這個值),隨著$intRand的逐漸增大,array_unique的表現更好,我不使用$intTotal/$intRand這個比值,是因為,感覺并不是成比例變化,但是基本會遵循比值越大,array_unique表現越好。

綜上所述,在過濾數組重復值的時候,建議使用array_unuique,數組不大的時候兩者效率等同,而array_unique使用當然讓你的代碼一下子減了好幾行,數組容量過大時,函數的表現更好,為什么不用呢?

php技術PHP兩種去掉數組重復值的方法比較,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 日本不卡在线视频 | 欧美区日韩区 | 日本在线中文 | 一级网站 | 亚洲小视频 | 国产福利91精品一区二区三区 | 在线成人av | 亚洲一级毛片 | 欧美一级欧美三级在线观看 | 日韩高清av | 日本三级日产三级国产三级 | 日韩欧美不卡 | 色婷婷综合久久久中字幕精品久久 | 久在线视频 | 亚洲成人网在线 | 中文精品久久 | 日韩视频专区 | 欧美成人精品 | 91在线视频网址 | 在线视频a | 天天天天天天天干 | 日韩免费一二三区 | 日韩成人精品一区二区三区 | 日本不卡免费新一二三区 | 中文字幕国产日韩 | 欧美成人自拍 | 日韩精品久久一区 | 国产一区电影 | 久久精品一区二区三区四区 | 免费看片国产 | 欧美在线a | 日韩视频中文字幕 | 欧美精品第三页 | 日本不卡高清视频 | 男人天堂手机在线视频 | 天天躁日日躁狠狠躁白人 | 一级看片| 午夜视频在线观看网址 | 黄色一级免费 | 日本不卡一区 | 国产欧美精品在线观看 |