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

過濾掉PHP數組中的重復值的實現代碼

復制代碼 代碼如下:
<?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數組中的重復值的實現代碼,轉載需保留來源!

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

主站蜘蛛池模板: 中文字幕在线免费观看 | 在线观看国产 | 成人老司机 | 午夜伊人 | 91豆花视频 | 操视频网站 | 久久99精品久久久久婷婷 | 不卡一区二区在线观看 | 日韩视频一区在线观看 | 午夜免费电影 | 国产综合久久 | 完全免费av在线 | 91就要激情 | 成人免费视频网站在线看 | 五月婷婷色 | 一道本在线 | 色视频www在线播放国产人成 | 国产综合精品一区二区三区 | 日韩精品人成在线播放 | 亚洲国产一区在线 | 羞羞网站免费 | 国产日韩视频在线 | 亚洲免费在线视频 | 国产乱码精品一区二区三区中文 | 免费看一级毛片 | 亚洲视频www | 久操国产 | 亚洲精品乱码久久久久v最新版 | 日日操视频 | 国产成人免费视频 | 久久精品视频在线观看 | 福利视频三区 | 国产一区二区三区久久久久久久久 | 国产中文在线观看 | 久久九| 九色 在线 | 午夜精品久久久久久久久久久久 | 国产精品伦一区二区三级视频 | 99草免费视频 | 日韩色在线 | 毛片免费看 |