in_array大數組查詢效能問題

來源:互聯網
上載者:User
問題

最近在實現一個項目介面的時候發現當數組過大的時候,資料返回的速度有點慢。介面資料返回最長反應時間2s,經過反覆調試發現程式碼片段耗時最長的部分在in_array()函數。

解決過程

在stackoverflow找到了一篇提供我解決思路的文章
- which is faster, array_key_exists or array_search?

文中說到:

array_key_exists is much faster. array_search must traverse the whole array, so it is O(n). array_key_exists is a hash table lookup, so it is O(1).

----分割線----

I think it’s faster for PHP to check for keys (array_key_exists() or simply isset($array[$key])). To search for a value, PHP must cycle through the array; to search for a key PHP will use a hash function.

該數組是用來儲存使用者帳號,一直不銷毀儲存在記憶體。

原數組
$array=array('account1','account2','$account3');

修改後的數組
$array=array('account1'=>0,'account2'=>0,'$account3'=>0)

使用isset($array[$account])) 來檢測帳號是否存在該數組內

總結

由於in_array()函數對數組進行遍曆查詢,O(n),隨n(數組長度)的增大耗時將增加。所以在對大數組使用in_array()函數應考慮效率問題。

當面對大數組查詢的時候,在PHP中應該盡量採用key查詢而不是value查詢。

').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i <= lines; i++) { $numbering.append($('
  • ').text(i)); }; $numbering.fadeIn(1700); }); });

    以上就介紹了in_array大數組查詢效能問題,包括了方面的內容,希望對PHP教程有興趣的朋友有所協助。

  • 聯繫我們

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

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

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.