摘要:原文來自原文概述使用的函數(shù)允許你傳遞一個(gè)數(shù)組,然后移除重復(fù)的值,返回一個(gè)擁有唯一值的數(shù)組。有一個(gè)比較好而且更快的函數(shù)來替代使用函數(shù)來創(chuàng)建唯一的數(shù)組。
原文來自: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()函數(shù)允許你傳遞一個(gè)數(shù)組,然后移除重復(fù)的值,返回一個(gè)擁有唯一值的數(shù)組。這個(gè)函數(shù)大多數(shù)情況下都能工作得很好。但是,如果你嘗試在一個(gè)大的數(shù)組里使用array_unique()函數(shù),它會(huì)運(yùn)行地慢一些。
有一個(gè)比較好而且更快的函數(shù)array_flip()來替代使用array_unique()函數(shù)來創(chuàng)建唯一的數(shù)組。這個(gè)魔法般的函數(shù)會(huì)交換數(shù)組里面每一個(gè)元素的鍵和值,因?yàn)殒I值必須唯一,因此,你會(huì)得到跟array_unique()函數(shù)一樣的結(jié)果。
更快的方式實(shí)現(xiàn)PHP數(shù)組去重/* 創(chuàng)建一個(gè)包含重復(fù)值的,一共四個(gè)元素的數(shù)組 */ $array = array("green","blue","orange","blue"); /* 翻轉(zhuǎn)數(shù)組,你將會(huì)得到唯一鍵值的數(shù)組 array("green"=>0,"blue"=>1,"orange"=>2); */ $array = array_flip($array); /* 然后再翻轉(zhuǎn)一次,將鍵和值重新放置,然后得到數(shù)組:array(0=>"green",1=>"blue",2=>"orange"); */ $array = array_flip($array);
因?yàn)槲覀円呀?jīng)移除了一些元素,因此數(shù)組看起來不是正常的序列。比如我們可能會(huì)得到:array(0=>"A",2=>"B",5=>"C");。在某些情況下,這不是一個(gè)問題,但是如果你需要數(shù)組的鍵值保持?jǐn)?shù)字的序列,你可以使用一到兩種方法解決鍵值亂序的問題。
使用array_merge修復(fù)數(shù)組的keys添加array_flip之后的函數(shù),將會(huì)對(duì)數(shù)組的鍵值排序并且讓它們恢復(fù)到正常的序列,如:0,1,2,3...
$array = array("green","blue","orange","blue"); $array = array_flip($array); $array = array_flip($array); /* 使用array_merge()函數(shù)修復(fù)鍵值*/ $array = array_merge($array);第二種方式,使用array_keys
注意,這種修復(fù)數(shù)組鍵值的方法比使用array_merge()函數(shù)稍微快了一點(diǎn)。你也可以在最后一步結(jié)合使用array_keys()函數(shù)(此函數(shù)返回翻轉(zhuǎn)后的值)。然后當(dāng)你翻轉(zhuǎn)數(shù)組的值,鍵值就會(huì)根據(jù)順序創(chuàng)建。
$array = array("green","blue","orange","blue"); $array = array_flip($array); /* 跟第一個(gè)例子一樣,但是現(xiàn)在我們先提取數(shù)組的鍵值 */ $array = array_keys($array);結(jié)論
非常簡(jiǎn)單,比起在大數(shù)組使用array_unique函數(shù),有了一個(gè)有效的性能提升。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/21320.html
摘要:由于原文沒有給出源碼分析和測(cè)試的結(jié)果,導(dǎo)致給讀者造成迷惑,在此說聲抱歉。測(cè)試結(jié)果表明,使用后再調(diào)用函數(shù)比函數(shù)快。結(jié)論因?yàn)榈讓诱{(diào)用了快排算法,加大了函數(shù)運(yùn)行的時(shí)間開銷,導(dǎo)致整個(gè)函數(shù)的運(yùn)行較慢。 文章來自:http://www.hoohack.me/2016/02/25/analyze-array-unique-array-keys-source-code 我在github有對(duì)PHP源碼更...
摘要:參數(shù)用來測(cè)試數(shù)組的每個(gè)元素的函數(shù)。調(diào)用時(shí)使用參數(shù)。返回表示保留該元素通過測(cè)試,則不保留。執(zhí)行時(shí)的用于的值。那些沒有通過測(cè)試的元素會(huì)被跳過,不會(huì)被包含在新數(shù)組中。有其他好的方法或思路的道友,不妨在沙發(fā)區(qū)神交一番。 需求 給出一個(gè)類數(shù)組,刪除要求的重復(fù)數(shù)據(jù),返回新數(shù)組 destroyer([1, 2, 3, 1, 2, 3], 2, 3) should return [1, 1] dest...
摘要:前端面試題總結(jié),持續(xù)更新和區(qū)別瀏覽器的緩存機(jī)制提供了可以將用戶數(shù)據(jù)存儲(chǔ)在客戶端上的方式,可以利用等跟服務(wù)端進(jìn)行數(shù)據(jù)交互。 前端面試題總結(jié),持續(xù)更新 cookies sessionStorage和localstorage區(qū)別 瀏覽器的緩存機(jī)制提供了可以將用戶數(shù)據(jù)存儲(chǔ)在客戶端上的方式,可以利用cookie,session等跟服務(wù)端進(jìn)行數(shù)據(jù)交互。相同點(diǎn):都是存儲(chǔ)在客戶端不同點(diǎn):showI...
摘要:前端面試題總結(jié),持續(xù)更新和區(qū)別瀏覽器的緩存機(jī)制提供了可以將用戶數(shù)據(jù)存儲(chǔ)在客戶端上的方式,可以利用等跟服務(wù)端進(jìn)行數(shù)據(jù)交互。 前端面試題總結(jié),持續(xù)更新 cookies sessionStorage和localstorage區(qū)別 瀏覽器的緩存機(jī)制提供了可以將用戶數(shù)據(jù)存儲(chǔ)在客戶端上的方式,可以利用cookie,session等跟服務(wù)端進(jìn)行數(shù)據(jù)交互。相同點(diǎn):都是存儲(chǔ)在客戶端不同點(diǎn):showI...
摘要:前端面試題總結(jié),持續(xù)更新和區(qū)別瀏覽器的緩存機(jī)制提供了可以將用戶數(shù)據(jù)存儲(chǔ)在客戶端上的方式,可以利用等跟服務(wù)端進(jìn)行數(shù)據(jù)交互。 前端面試題總結(jié),持續(xù)更新 cookies sessionStorage和localstorage區(qū)別 瀏覽器的緩存機(jī)制提供了可以將用戶數(shù)據(jù)存儲(chǔ)在客戶端上的方式,可以利用cookie,session等跟服務(wù)端進(jìn)行數(shù)據(jù)交互。相同點(diǎn):都是存儲(chǔ)在客戶端不同點(diǎn):showI...
閱讀 2902·2023-04-26 02:14
閱讀 3751·2019-08-30 15:55
閱讀 1843·2019-08-29 16:42
閱讀 2757·2019-08-26 11:55
閱讀 2846·2019-08-23 13:38
閱讀 480·2019-08-23 12:10
閱讀 1308·2019-08-23 11:44
閱讀 2790·2019-08-23 11:43