php判斷數(shù)組元素中是否存在某個字符串的方法
方法一:采用in_array(value,array,type)
type 可選。如果設置該參數(shù)為 true,則檢查搜索的數(shù)據(jù)與數(shù)組的值的類型是否相同。
$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() 函數(shù)判斷某個數(shù)組中是否存在指定的 key,如果該 key 存在,則返回 true,否則返回 false。array_key_exists(key,array
方法三:
array_search() 函數(shù)與 in_array() 一樣,在數(shù)組中查找一個鍵值。如果找到了該值,匹配元素的鍵名會被返回。如果沒找到,則返回 false。array_search(value,array,strict),當數(shù)據(jù)量比較大的時候,用array_key_exists比較合適,但占用的內(nèi)存比較大,
數(shù)組結(jié)構是: array(1, 2, 3, ..)和 array(1 => true, 2 => false, ..),內(nèi)存使用比值為1:2。
具體跟內(nèi)部實現(xiàn)有關系,在php中第一種和第二種的數(shù)據(jù)結(jié)構類似,都是關聯(lián)數(shù)組。
其它補充:
查找一個元素是否在數(shù)組中,一共有下面三種做法:
in_array '函數(shù)在數(shù)組中搜索給定的值。in_array(value,array,type)type 可選。如果設置該參數(shù)為 true,則檢查搜索的數(shù)據(jù)與數(shù)組的值的類型是否相同。
array_key_exists 'array_key_exists() 函數(shù)判斷某個數(shù)組中是否存在指定的 key,如果該 key 存在,則返回 true,否則返回 false。
array_key_exists(key,array)
array_search 'array_search() 函數(shù)與 in_array() 一樣,在數(shù)組中查找一個鍵值。如果找到了該值,匹配元素的鍵名會被返回。如果沒找到,則返回 false。
array_search(value,array,strict)
從這里來看,在數(shù)據(jù)量不大的時候,比如小于1000,查找用哪一種都行,都不會成為瓶頸;
當數(shù)據(jù)量比較大的時候,用array_key_exists比較合適。
當然這里array_key_exists占用的內(nèi)存比較大,經(jīng)測算
數(shù)組結(jié)構是: array(1, 2, 3, ..)和 array(1 => true, 2 => false, ..)
他們內(nèi)存使用比值為1:2;
這個和內(nèi)部實現(xiàn)有關系,實際上在php中第一種和第二種的數(shù)據(jù)結(jié)構類似,都是關聯(lián)數(shù)組。
相關文章
php查詢mysql大量數(shù)據(jù)造成內(nèi)存不足的解決方法
這篇文章主要介紹了php查詢mysql大量數(shù)據(jù)造成內(nèi)存不足的解決方法,實例分析了mysql查詢時內(nèi)存不足的原因與相應的解決方法,并且較為詳細的分析了mysql_unbuffered_query函數(shù)的使用技巧,需要的朋友可以參考下2015-03-03

