国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

【譯】更快的方式實現PHP數組去重

岳光 / 3461人閱讀

摘要:原文來自原文概述使用的函數允許你傳遞一個數組,然后移除重復的值,返回一個擁有唯一值的數組。有一個比較好而且更快的函數來替代使用函數來創建唯一的數組。

原文來自:http://www.hoohack.me/2016/01/11/faster-way-to-phps-array-unique-function/

原文:Faster Alternative to PHP’s Array Unique Function

概述

使用PHP的array_unique()函數允許你傳遞一個數組,然后移除重復的值,返回一個擁有唯一值的數組。這個函數大多數情況下都能工作得很好。但是,如果你嘗試在一個大的數組里使用array_unique()函數,它會運行地慢一些。

有一個比較好而且更快的函數array_flip()來替代使用array_unique()函數來創建唯一的數組。這個魔法般的函數會交換數組里面每一個元素的鍵和值,因為鍵值必須唯一,因此,你會得到跟array_unique()函數一樣的結果。

更快的方式實現PHP數組去重
/* 創建一個包含重復值的,一共四個元素的數組 */
$array = array("green","blue","orange","blue");

/* 翻轉數組,你將會得到唯一鍵值的數組
        array("green"=>0,"blue"=>1,"orange"=>2); */
$array = array_flip($array);

/* 然后再翻轉一次,將鍵和值重新放置,然后得到數組:array(0=>"green",1=>"blue",2=>"orange"); */
$array = array_flip($array);

因為我們已經移除了一些元素,因此數組看起來不是正常的序列。比如我們可能會得到:array(0=>"A",2=>"B",5=>"C");。在某些情況下,這不是一個問題,但是如果你需要數組的鍵值保持數字的序列,你可以使用一到兩種方法解決鍵值亂序的問題。

使用array_merge修復數組的keys

添加array_flip之后的函數,將會對數組的鍵值排序并且讓它們恢復到正常的序列,如:0,1,2,3...

$array = array("green","blue","orange","blue");
$array = array_flip($array);
$array = array_flip($array);

/* 使用array_merge()函數修復鍵值*/
$array = array_merge($array);
第二種方式,使用array_keys

注意,這種修復數組鍵值的方法比使用array_merge()函數稍微快了一點。你也可以在最后一步結合使用array_keys()函數(此函數返回翻轉后的值)。然后當你翻轉數組的值,鍵值就會根據順序創建。

$array = array("green","blue","orange","blue");
$array = array_flip($array);
/* 跟第一個例子一樣,但是現在我們先提取數組的鍵值 */
$array = array_keys($array);
結論

非常簡單,比起在大數組使用array_unique函數,有了一個有效的性能提升。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/21320.html

相關文章

  • 【性能為王】從PHP源碼剖析array_keys和array_unique

    摘要:由于原文沒有給出源碼分析和測試的結果,導致給讀者造成迷惑,在此說聲抱歉。測試結果表明,使用后再調用函數比函數快。結論因為底層調用了快排算法,加大了函數運行的時間開銷,導致整個函數的運行較慢。 文章來自:http://www.hoohack.me/2016/02/25/analyze-array-unique-array-keys-source-code 我在github有對PHP源碼更...

    zollero 評論0 收藏0
  • 】JS基礎算法腳本:類數組(arguments)去重

    摘要:參數用來測試數組的每個元素的函數。調用時使用參數。返回表示保留該元素通過測試,則不保留。執行時的用于的值。那些沒有通過測試的元素會被跳過,不會被包含在新數組中。有其他好的方法或思路的道友,不妨在沙發區神交一番。 需求 給出一個類數組,刪除要求的重復數據,返回新數組 destroyer([1, 2, 3, 1, 2, 3], 2, 3) should return [1, 1] dest...

    mrcode 評論0 收藏0
  • 前端面試題

    摘要:前端面試題總結,持續更新和區別瀏覽器的緩存機制提供了可以將用戶數據存儲在客戶端上的方式,可以利用等跟服務端進行數據交互。 前端面試題總結,持續更新 cookies sessionStorage和localstorage區別 瀏覽器的緩存機制提供了可以將用戶數據存儲在客戶端上的方式,可以利用cookie,session等跟服務端進行數據交互。相同點:都是存儲在客戶端不同點:showI...

    raledong 評論0 收藏0
  • 前端面試題

    摘要:前端面試題總結,持續更新和區別瀏覽器的緩存機制提供了可以將用戶數據存儲在客戶端上的方式,可以利用等跟服務端進行數據交互。 前端面試題總結,持續更新 cookies sessionStorage和localstorage區別 瀏覽器的緩存機制提供了可以將用戶數據存儲在客戶端上的方式,可以利用cookie,session等跟服務端進行數據交互。相同點:都是存儲在客戶端不同點:showI...

    seal_de 評論0 收藏0
  • 前端面試題

    摘要:前端面試題總結,持續更新和區別瀏覽器的緩存機制提供了可以將用戶數據存儲在客戶端上的方式,可以利用等跟服務端進行數據交互。 前端面試題總結,持續更新 cookies sessionStorage和localstorage區別 瀏覽器的緩存機制提供了可以將用戶數據存儲在客戶端上的方式,可以利用cookie,session等跟服務端進行數據交互。相同點:都是存儲在客戶端不同點:showI...

    xiaoqibTn 評論0 收藏0

發表評論

0條評論

岳光

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<