溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何理解PHP in_array 函數(shù)

發(fā)布時(shí)間:2021-10-08 10:40:20 來源:億速云 閱讀:133 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“如何理解PHP in_array 函數(shù)”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

但是如果數(shù)組比較大的時(shí)候,性能就會(huì)下降,運(yùn)行的就會(huì)久一點(diǎn),那如果針對(duì)在大數(shù)組情況下做優(yōu)化呢,下面說兩種方法(都是通過自定義函數(shù)來實(shí)現(xiàn)):

1.數(shù)組key與value翻轉(zhuǎn),通過isset判斷key是否存在于數(shù)組中

復(fù)制代碼 代碼如下:

/**
 * in_array is too slow when array is large
 */
public static function inArray($item, $array) {
    $flipArray = array_flip($array);
    return isset($flipArray[$item]);
}


大家可能也會(huì)問為什么不用 array_key_exists 來做判斷二用isset呢? 下面看下array_key_exists() 與 isset() 的對(duì)比:
isset()對(duì)于數(shù)組中為NULL的值不會(huì)返回TRUE,而array_key_exists()會(huì)。

復(fù)制代碼 代碼如下:

<?php
$search_array = array('first' => null, 'second' => 4);

// returns false
isset($search_array['first']);

// returns true
array_key_exists('first', $search_array);
?>
2.用implode連接,直接用strpos判斷

用implode函數(shù)+逗號(hào)連起來,直接用strpos判斷。php里面字符串取位置速度非???,尤其是在大數(shù)據(jù)量的情況下。不過需要注意的是首尾都要加”,” ,這樣比較嚴(yán)謹(jǐn)。如: ,user1,user2,user3, 查找的時(shí)候,查,user1,。還有strpos要用!== false,因?yàn)榈谝粋€(gè)會(huì)返回0。示例如下:

復(fù)制代碼 代碼如下:

/**
 * in_array is too slow when array is large
 */
public static function inArray($item, $array) {
    $str = implode(',', $array);
    $str = ',' . $str . ',';
    $item = ',' . $item . ',';
    return false !== strpos($item, $str) ? true : false;
}

“如何理解PHP in_array 函數(shù)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI