方法一:採用in_array(value,array,type)
type 可選。如果設定該參數為 true,則檢查搜尋的資料與數組的值的類型是否相同。
.代碼如下:
$arr = array('可以','如何','方法','知道','沒有','不要');
//in_array(value,array,type)
$isin = in_array("如何2",$arr);
if($isin){
echo "in====".$isin;
}else{
echo "out====".$isin;
}
方法二:
array_key_exists 'array_key_exists() 函數判斷某個數組中是否存在指定的 key,如果該 key 存在,則返回 true,否則返回 false。array_key_exists(key,array
方法三:
array_search() 函數與 in_array() 一樣,在數組中尋找一個索引值。如果找到了該值,匹配元素的鍵名會被返回。如果沒找到,則返回 false。array_search(value,array,strict),當資料量比較大的時候,用array_key_exists比較合適,但佔用的記憶體比較大,
數組結構是: array(1, 2, 3, ..)和 array(1 => true, 2 => false, ..),記憶體使用量比值為1:2。
具體跟內部實現有關係,在php中第一種和第二種的資料結構類似,都是關聯陣列。
其它補充:
尋找一個元素是否在數組中,一共有下面三種做法:
in_array '函數在數組中搜尋給定的值。in_array(value,array,type)type 可選。如果設定該參數為 true,則檢查搜尋的資料與數組的值的類型是否相同。
array_key_exists 'array_key_exists() 函數判斷某個數組中是否存在指定的 key,如果該 key 存在,則返回 true,否則返回 false。
array_key_exists(key,array)
array_search 'array_search() 函數與 in_array() 一樣,在數組中尋找一個索引值。如果找到了該值,匹配元素的鍵名會被返回。如果沒找到,則返回 false。
array_search(value,array,strict)
從這裡來看,在資料量不大的時候,比如小於1000,尋找用哪一種都行,都不會成為瓶頸;
當資料量比較大的時候,用array_key_exists比較合適。
當然這裡array_key_exists佔用的記憶體比較大,經測算
數組結構是: array(1, 2, 3, ..)和 array(1 => true, 2 => false, ..)
他們記憶體使用量比值為1:2;
這個和內部實現有關係,實際上在php中第一種和第二種的資料結構類似,都是關聯陣列。