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

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

原文: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');。在某些狀況下,這不是一個問題,可是若是你須要數組的鍵值保持數字的序列,你可使用一到兩種方法解決鍵值亂序的問題。code

使用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()函數(此函數返回翻轉後的值)。而後當你翻轉數組的值,鍵值就會根據順序建立。ip

$array = array('green','blue','orange','blue');
$array = array_flip($array);
/* 跟第一個例子同樣,可是如今咱們先提取數組的鍵值 */
$array = array_keys($array);

結論

很是簡單,比起在大數組使用array_unique函數,有了一個有效的性能提高。get

相關文章
相關標籤/搜索