一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專(zhuān)注于服務(wù)器技術(shù)及軟件下載分享
分類(lèi)導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - PHP教程 - php 數(shù)組元素快速去重

php 數(shù)組元素快速去重

2021-05-16 22:41傲雪星楓 PHP教程

本篇文章主要介紹了php數(shù)組元素快速去重的方法,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧

1.使用array_unique方法進(jìn)行去重

對(duì)數(shù)組元素進(jìn)行去重,我們一般會(huì)使用array_unique方法,使用這個(gè)方法可以把數(shù)組中的元素去重。

?
1
2
3
4
5
6
<?php
$arr = array(1,1,2,3,3,3,4,4,5,6,6,7,8,8,9,9,9);
$arr = array_unique($arr);
$arr = array_values($arr);
print_r($arr);
?>

輸出:

?
1
2
3
4
5
6
7
8
9
10
11
12
Array
(
  [0] => 1
  [1] => 2
  [2] => 3
  [3] => 4
  [4] => 5
  [5] => 6
  [6] => 7
  [7] => 8
  [8] => 9
)

去重后,鍵值會(huì)不按順序,可以使用array_values把鍵值重新排序。

2.使用array_unique方法去重效率

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
<?php
$arr = array();
 
// 創(chuàng)建100000個(gè)隨機(jī)元素的數(shù)組
for($i=0; $i<100000; $i++){
  $arr[] = mt_rand(1,99);
}
 
// 記錄開(kāi)始時(shí)間
$starttime = getMicrotime();
 
// 去重
$arr = array_unique($arr);
 
// 記錄結(jié)束時(shí)間
$endtime = getMicrotime();
 
$arr = array_values($arr);
 
echo 'unique count:'.count($arr).'<br>';
echo 'run time:'.(float)(($endtime-$starttime)*1000).'ms<br>';
echo 'use memory:'.getUseMemory();
 
/**
 * 獲取使用內(nèi)存
 * @return float
 */
function getUseMemory(){
  $use_memory = round(memory_get_usage(true)/1024,2).'kb';
  return $use_memory;
}
/**
 * 獲取microtime
 * @return float
 */
function getMicrotime(){
  list($usec, $sec) = explode(' ', microtime());
  return (float)$usec + (float)$sec;
}
?>

unique count:99
run time:653.39303016663ms
use memory:5120kb

使用array_unique方法去重,運(yùn)行時(shí)間需要約650ms,內(nèi)存占用約5m

3.更快的數(shù)組去重方法

PHP有一個(gè)鍵值互換的方法array_flip,我們可以使用這個(gè)方法去重,因?yàn)殒I值互換,原來(lái)重復(fù)的值會(huì)變?yōu)橄嗤逆I。

然后再進(jìn)行一次鍵值互換,把鍵和值換回來(lái)則可以完成去重。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
<?php
$arr = array();
 
// 創(chuàng)建100000個(gè)隨機(jī)元素的數(shù)組
for($i=0; $i<100000; $i++){
  $arr[] = mt_rand(1,99);
}
 
// 記錄開(kāi)始時(shí)間
$starttime = getMicrotime();
 
// 使用鍵值互換去重
$arr = array_flip($arr);
$arr = array_flip($arr);
 
// 記錄結(jié)束時(shí)間
$endtime = getMicrotime();
 
$arr = array_values($arr);
 
echo 'unique count:'.count($arr).'<br>';
echo 'run time:'.(float)(($endtime-$starttime)*1000).'ms<br>';
echo 'use memory:'.getUseMemory();
 
/**
 * 獲取使用內(nèi)存
 * @return float
 */
function getUseMemory(){
  $use_memory = round(memory_get_usage(true)/1024,2).'kb';
  return $use_memory;
}
/**
 * 獲取microtime
 * @return float
 */
function getMicrotime(){
  list($usec, $sec) = explode(' ', microtime());
  return (float)$usec + (float)$sec;
}
?>

unique count:99
run time:12.840032577515ms
use memory:768kb

使用array_flip方法去重,運(yùn)行時(shí)間需要約18ms,內(nèi)存占用約2m

因此使用array_flip方法去重比使用array_unique方法運(yùn)行時(shí)間減少98%,內(nèi)存占用減少4/5;

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持服務(wù)器之家!

原文鏈接:http://blog.csdn.net/fdipzone/article/details/50573353

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 免费一级毛片在级播放 | 暴露狂婷婷医院暴露tx | 久久这里只有精品国产精品99 | 欧美ay| 手机在线观看伦理片 | 午夜第一页 | 久青草国产在线观看视频 | 77色视频在线 | 天天操免费视频 | 99热久久这里只有精品6国产网 | 希望影院高清免费观看视频 | 攻插受 | 亚洲网站在线看 | 欧美日韩中文字幕在线视频 | 欧洲肥女大肥臀tv | 日韩资源| chinese军人@gay | 国产主播99 | 大学生情侣在线 | 呜呜别塞了啊抽插 | 日本三级免费观看 | 小SAO货叫大声点妓女 | 我的男友是消防员在线观看 | 精品久久成人免费第三区 | 人成网站在线观看 | 欧美一级专区免费大片 | 国产欧美精品一区二区三区–老狼 | 亚洲成年网站在线777 | japanese在线看| 亚州性夜夜射在线观看 | 欧美性色黄大片四虎影视 | 国产高清视频在线 | 免费观看一区二区 | 国产精品视频一区二区三区w | 日本特黄一级午夜剧场毛片 | 丰满肥臀风间由美357在线 | 日韩毛片在线影视 | 色老板视频在线 | 欧美色图日韩色图 | 草草视频人人爽 | 五月色婷婷久久综合 |