深思 PHP 數組遍曆的差異(array_diff 的實現)

來源:互聯網
上載者:User

function array_diff($array_1, $array_2) {
$diff = array();

foreach ($array_1 as $k => $v1) {
$flag = false;
foreach ($array_2 as $v2) {
if ($flag = ($v1 == $v2)) {
break;
}
}

if (!$flag) {
$diff[$k] = $v1;
}
}

return $diff;
}雖然實現是可以的,但是發現這個函數的效率是慘不忍睹。於是我又重新考慮了下,並最佳化了演算法,第二個函數看起來是這個樣子的:

function array_diff($array_1, $array_2) {
foreach ($array_1 as $key => $item) {
if (in_array($item, $array_2, true)) {
unset($array_1[$key]);
}
}

return $array_1;
}嗯,這次幾乎可以和原 array_diff 函數的速度媲美了。但是還有沒有更最佳化的辦法呢?由 ChinaUnix 上的一篇文章(不好意思,作弊了),我發現 PHP 竟然可以這樣寫:

function array_diff($array_1, $array_2) {
$array_2 = array_flip($array_2);
foreach ($array_1 as $key => $item) {
if (isset($array_2[$item])) {
unset($array_1[$key]);
}
}

return $array_1;
}這個函數的效率非常的驚人,甚至比原 array_diff 函數的速度都要快。究其原因,我找到瞭解釋:

因為鍵是進行 HASH 組織的,尋找很快;
而 Value 只是由 Key 組織存放,本身沒有索引,每次尋找都是遍曆。總結
這雖然是 PHP 語言的一個小竅門,但在遍曆和對比數組的值上,如果需要對比值將其與鍵反轉的確比通常的值對值的比較效率要高得多。

比如,上面的函數二需要調用 in_array 函數需要迴圈判斷是否在函數內;而函數三則僅僅判斷這個數組是否存在該鍵就可以了。加上數組鍵和值不同的組織索引方式,效率比想象的還高那就非常可以理解了。

附代碼複製代碼 代碼如下:<?php
function microtime_float() {
list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec);
}

function array_diff2($array_1, $array_2) {
$diff = array();

foreach ($array_1 as $k => $v1) {
$flag = false;
foreach ($array_2 as $v2) {
if ($flag = ($v1 == $v2)) {
break;
}
}

if (!$flag) {
$diff[$k] = $v1;
}
}

return $diff;
}

function array_diff3($array_1, $array_2) {
foreach ($array_1 as $key => $item) {
if (in_array($item, $array_2, true)) {
unset($array_1[$key]);
}
}

return $array_1;
}

function array_diff4($array_1, $array_2) {
$array_2 = array_flip($array_2);
foreach ($array_1 as $key => $item) {
if (isset($array_2[$item])) {
unset($array_1[$key]);
}
}

return $array_1;
}

//////////////////////////////

for($i = 0, $ary_1 = array(); $i < 5000; $i++) {
$ary_1[] = rand(100, 999);
}

for($i = 0, $ary_2 = array(); $i < 5000; $i++) {
$ary_2[] = rand(100, 999);
}

header("Content-type: text/plain;charset=utf-8");

$time_start = microtime_float();
array_diff($ary_1, $ary_2);
echo "函數 array_diff 運行" . (microtime_float() - $time_start) . " 秒\n";

$time_start = microtime_float();
array_diff2($ary_1, $ary_2);
echo "函數 array_diff2 運行" . (microtime_float() - $time_start) . " 秒\n";

$time_start = microtime_float();
array_diff3($ary_1, $ary_2);
echo "函數 array_diff3 運行" . (microtime_float() - $time_start) . " 秒\n";

$time_start = microtime_float();
array_diff4($ary_1, $ary_2);
echo "函數 array_diff4 運行" . (microtime_float() - $time_start) . " 秒\n";
?>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.