欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

2個自定義的PHP in_array 函數(shù),解決大量數(shù)據(jù)判斷in_array的效率問題

 更新時間:2014年04月08日 17:28:02   作者:  
大家可能都用過in_array來判斷一個數(shù)據(jù)是否在一個數(shù)組中,一般我們的數(shù)組可能數(shù)據(jù)都比較小,對性能沒什么影響,所以也就不會太在意

但是如果數(shù)組比較大的時候,性能就會下降,運行的就會久一點,那如果針對在大數(shù)組情況下做優(yōu)化呢,下面說兩種方法(都是通過自定義函數(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]);
}

大家可能也會問為什么不用 array_key_exists 來做判斷二用isset呢? 下面看下array_key_exists() 與 isset() 的對比:
isset()對于數(shù)組中為NULL的值不會返回TRUE,而array_key_exists()會。
復(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ù)+逗號連起來,直接用strpos判斷。php里面字符串取位置速度非??欤绕涫窃诖髷?shù)據(jù)量的情況下。不過需要注意的是首尾都要加”,” ,這樣比較嚴謹。如: ,user1,user2,user3, 查找的時候,查,user1,。還有strpos要用!== false,因為第一個會返回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;
}

相關(guān)文章

最新評論