foreach ($array_1 as $k => $v1) { $flag = false; foreach ($array_2 as $v2) { if ($flag = ($v1 == $v2)) " /> 成年人视频在线免费看,忘忧草研究所 麻豆,日本人娇小hd

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

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

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";
?>


php技術深思 PHP 數組遍歷的差異(array_diff 的實現),轉載需保留來源!

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

主站蜘蛛池模板: 亚洲中文字幕乱倫在线 | 亚洲AV综合色一区二区三区 | 美女一级毛片免费不卡视频 | 中文字幕无码他人妻味 | 蜜芽丅v新网站在线观看 | 欧美成人亚洲高清在线观看 | 国产精品日本不卡一区二区 | 国产福利秒拍weipai.ee | 四虎国产精品永久一区高清 | 97色伦图片7778久久 | 老师别揉我胸啊嗯小说 | 动漫美女被吸奶 | 久久中文字幕综合不卡一二区 | 国产GV天堂亚洲国产GV刚刚碰 | 久久精品亚洲 | 天天久久影视色香综合网 | 国产69精品久久久久APP下载 | 亚洲欧美综合在线中文 | 亚洲精品tv久久久久久久久久 | 国产AV无码一二三区视频 | 色综合久久天天影视网 | 给我免费播放片bd国语 | 9988电影网| 国产三级91| 嗯别插太快好深再深点 | 成片在线看一区二区草莓 | 俄罗斯乌克兰战争原因 | 纯肉无码AV在线看免费看 | 我在厨房摸岳的乳HD在线观看 | 精品国产国产精2020久久日 | 在线 亚洲 日韩 欧洲视频 | 陈红下面又紧又小好爽 | 亚洲免费观看视频 | 亚洲九九视频 | 久久久久久免费高清电影 | 久久人妻少妇嫩草AV蜜桃35I | ewp绞死vk失禁编 | 美国色情三级欧美三级纸匠情挑 | 免费观看视频成人国产 | 噼里啪啦免费观看视频大全 | 久热久热精品在线观看 |