2個自訂的PHP in

來源:互聯網
上載者:User

 但是如果數組比較大的時候,效能就會下降,啟動並執行就會久一點,那如果針對在大數組情況下做最佳化呢,下面說兩種方法(都是通過自訂函數來實現):

 1.數組key與value翻轉,通過isset判斷key是否存在於數組中  代碼如下:/** * 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()對於數組中為NULL的值不會返回TRUE,而array_key_exists()會。 代碼如下:<?php$search_array = array('first' => null, 'second' => 4); // returns falseisset($search_array['first']); // returns truearray_key_exists('first', $search_array);?> 2.用implode串連,直接用strpos判斷 用implode函數+逗號連起來,直接用strpos判斷。php裡面字串取位置速度非常快,尤其是在大資料量的情況下。不過需要注意的是首尾都要加”,” ,這樣比較嚴謹。如: ,user1,user2,user3, 尋找的時候,查,user1,。還有strpos要用!== false,因為第一個會返回0。樣本如下:  代碼如下:/** * 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;} 
相關文章

Beyond APAC's No.1 Cloud

19.6% IaaS Market Share in Asia Pacific - Gartner IT Service report, 2018

Learn more >

Apsara Conference 2019

The Rise of Data Intelligence, September 25th - 27th, Hangzhou, China

Learn more >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。