Cara melaksanakan deduplikasi tatasusunan dalam PHP: 1. Gunakan kaedah array_unique untuk menyahduplikasi elemen tatasusunan 2. Gunakan kaedah array_flip untuk menyahduplikasi.
Persekitaran pengendalian artikel ini: sistem Windows 7, PHP versi 7.1, komputer DELL G3
deduplikasi pantas elemen tatasusunan php
1. Gunakan kaedah array_unique untuk menyahduplikasi
Untuk menyahduplikasi elemen tatasusunan, kami biasanya menggunakan kaedah array_unique.
<?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); ?>
Output:
Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 [5] => 6 [6] => 7 [7] => 8 [8] => 9 )
Selepas penyahduplikasi, nilai kunci akan menjadi tidak teratur Anda boleh menggunakan array_values untuk menyusun semula nilai kunci.
2. Kecekapan menggunakan kaedah array_unique untuk mengalih keluar pendua
<?php $arr = array(); // 创建100000个随机元素的数组 for($i=0; $i<100000; $i++){ $arr[] = mt_rand(1,99); } // 记录开始时间 $starttime = getMicrotime(); // 去重 $arr = array_unique($arr); // 记录结束时间 $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(); /** * 获取使用内存 * @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
Menggunakan kaedah array_unique untuk mengalih keluar pendua, masa berjalan mengambil masa kira-kira 650ms dan memori penggunaan adalah kira-kira 5m
3 Kaedah penyahduplikasi tatasusunan yang lebih pantas
php mempunyai kaedah pertukaran nilai kunci array_flip, kita boleh menggunakan kaedah ini untuk menyahduplikasi, kerana kunci- pertukaran nilai, Nilai pendua asal akan menjadi kunci yang sama.
Kemudian laksanakan pertukaran nilai kunci, dan tukar semula kunci dan nilai untuk melengkapkan penduadua.
<?php $arr = array(); // 创建100000个随机元素的数组 for($i=0; $i<100000; $i++){ $arr[] = mt_rand(1,99); } // 记录开始时间 $starttime = getMicrotime(); // 使用键值互换去重 $arr = array_flip($arr); $arr = array_flip($arr); // 记录结束时间 $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(); /** * 获取使用内存 * @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
Menggunakan kaedah array_flip untuk menyahduplikasi, masa berjalan mengambil masa kira-kira 18ms, dan penggunaan memori adalah kira-kira 2m
Oleh itu, menggunakan kaedah array_flip untuk menyahduplikasi masa berjalan adalah 98% lebih pendek daripada menggunakan kaedah array_unique dikurangkan sebanyak 4/5;
Pembelajaran yang disyorkan: "Tutorial Video PHP"
Atas ialah kandungan terperinci Bagaimana untuk melaksanakan deduplikasi tatasusunan dalam php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!