PHP+MySQL實(shí)現(xiàn)消息隊(duì)列的方法分析
以下是【金聰采編】分享的內(nèi)容全文:
本文實(shí)例講述了PHP數(shù)組去重的更快實(shí)現(xiàn)方式。分享給大家供大家參考,具體如下:
概述
使用PHP的array_unique()函數(shù)允許你傳遞一個(gè)數(shù)組,然后移除重復(fù)的值,返回一個(gè)擁有唯一值的數(shù)組。這個(gè)函數(shù)大多數(shù)情況下都能工作得很好。但是,如果你嘗試在一個(gè)大的數(shù)組里使用array_unique()函數(shù),它會(huì)運(yùn)行地慢一些。
有一個(gè)比較好而且更快的函數(shù)array_flip()來(lái)替代使用array_unique()函數(shù)來(lái)創(chuàng)建唯一的數(shù)組。這個(gè)魔法般的函數(shù)會(huì)交換數(shù)組里面每一個(gè)元素的鍵和值,因?yàn)殒I值必須唯一,因此,你會(huì)得到跟array_unique()函數(shù)一樣的結(jié)果。
PHP代碼:
/* 創(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);print_r($array)運(yùn)行結(jié)果:
Array( [0] => green [3] => blue [2] => orange)
因?yàn)槲覀円呀?jīng)移除了一些元素,因此數(shù)組看起來(lái)不是正常的序列。比如我們可能會(huì)得到:array(0=>'A',2=>'B',5=>'C');。在某些情況下,這不是一個(gè)問(wèn)題,但是如果你需要數(shù)組的鍵值保持?jǐn)?shù)字的序列,你可以使用一到兩種方法解決鍵值亂序的問(wèn)題。
使用array_merge修復(fù)數(shù)組的keys
添加array_flip之后的函數(shù),將會(huì)對(duì)數(shù)組的鍵值排序并且讓它們恢復(fù)到正常的序列,如:0,1,2,3…
PHP代碼:
$array = array('green','blue','orange','blue');$array = array_flip($array);$array = array_flip($array);/* 使用array_merge()函數(shù)修復(fù)鍵值*/$array = array_merge($array);print_r($array)運(yùn)行結(jié)果同上
第二種方式,使用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)建。
PHP代碼:
$array = array('green','blue','orange','blue');$array = array_flip($array);/* 跟第一個(gè)例子一樣,但是現(xiàn)在我們先提取數(shù)組的鍵值 */$array = array_keys($array);print_r($array)運(yùn)行結(jié)果同上
結(jié)論
非常簡(jiǎn)單,比起在大數(shù)組使用array_unique函數(shù),有了一個(gè)有效的性能提升。
PS:本站還有兩款比較簡(jiǎn)單實(shí)用的在線文本去重復(fù)工具,推薦給大家使用:
在線去除重復(fù)項(xiàng)工具:
http://tools.jb51.net/code/quchong
在線文本去重復(fù)工具:
http://tools.jb51.net/aideddesign/txt_quchong
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》、《php字符串(string)用法總結(jié)》、《php常用函數(shù)與技巧總結(jié)》、《PHP錯(cuò)誤與異常處理方法總結(jié)》、《PHP基本語(yǔ)法入門教程》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
1.軟件源碼推廣展示:目的展示軟件相關(guān)功能,接收技術(shù)學(xué)習(xí)者測(cè)試、測(cè)評(píng);
2.教程課程信息展示:展示課程信息,傳授課程各階段內(nèi)容;
3.設(shè)計(jì)素材圖片展示:展示素材設(shè)計(jì)理念、思維方式、傳播設(shè)計(jì)理念;
4.福利優(yōu)惠信息展示:分享各類最新的福利信息,各種優(yōu)惠信息展示;
以上分享目的僅供學(xué)習(xí)、參考使用,請(qǐng)勿用于其他用途,如果想商業(yè)使用或者代理,請(qǐng)自行聯(lián)系版權(quán)方獲取授權(quán)。任何未獲取授權(quán)的商業(yè)使用與本站無(wú)關(guān),請(qǐng)自行承擔(dān)相應(yīng)責(zé)任。
本站不存儲(chǔ)任何資源文件,敬請(qǐng)周知!
如果您認(rèn)為本頁(yè)信息內(nèi)容侵犯了您的相關(guān)權(quán)益(包含但不限于:著作權(quán)、首發(fā)權(quán)、隱私權(quán)等權(quán)利),或者您認(rèn)為自己是此信息的權(quán)利人但是此信息不是自己發(fā)布的,可以直接版權(quán)舉報(bào)投訴,我們會(huì)根據(jù)網(wǎng)站注冊(cè)協(xié)議、資源分享協(xié)議等協(xié)議處理,以保護(hù)您的合法權(quán)益。
本網(wǎng)站采用 BY-NC-SA 協(xié)議進(jìn)行授權(quán) 轉(zhuǎn)載請(qǐng)注明原文鏈接:PHP+MySQL實(shí)現(xiàn)消息隊(duì)列的方法分析

侵權(quán)舉報(bào)/版權(quán)申訴



