>백엔드 개발 >PHP 문제 >PHP에서 중복 데이터를 빠르게 제거하는 방법

PHP에서 중복 데이터를 빠르게 제거하는 방법

藏色散人
藏色散人원래의
2020-08-13 10:38:176377검색

PHP에서 중복 데이터를 제거하는 방법: 1. "array_unique" 메서드를 사용하여 배열 요소를 중복 제거하고 "array_values" 함수를 사용하여 키 값을 재정렬합니다. 2. "array_flip" 메서드를 사용하여 중복을 제거합니다.

PHP에서 중복 데이터를 빠르게 제거하는 방법

권장: "PHP 비디오 튜토리얼"

php 배열 요소의 빠른 중복 제거

1 array_unique 방법을 사용하여 중복 제거

배열 요소를 중복 제거하려면 일반적으로 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);
?>

출력:

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

중복 제거 후 키 값의 순서가 잘못됩니다. array_values를 사용하여 키 값을 재정렬할 수 있습니다.

2. array_unique 방법을 사용한 중복 제거 효율성

<?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 &#39;unique count:&#39;.count($arr).&#39;<br>&#39;;
echo &#39;run time:&#39;.(float)(($endtime-$starttime)*1000).&#39;ms<br>&#39;;
echo &#39;use memory:&#39;.getUseMemory();
/**
 * 获取使用内存
 * @return float
 */
function getUseMemory(){
    $use_memory = round(memory_get_usage(true)/1024,2).&#39;kb&#39;;
    return $use_memory;
}
/**
 * 获取microtime
 * @return float
 */
function getMicrotime(){
    list($usec, $sec) = explode(&#39; &#39;, microtime());
    return (float)$usec + (float)$sec;
}
?>
unique count:99
run time:653.39303016663ms
use memory:5120kb

array_unique 방법을 사용하여 중복 제거를 수행하면 실행 시간이 약 650ms가 걸리며 메모리 사용량은 약 5m

3 더 빨라진 배열 중복 제거 방법

php에는 array_flip이라는 키 값 교환 방법이 있습니다. 키 값이 교환되고 원래 중복 값이 ​​동일한 키가 되기 때문에 이 방법을 사용하여 중복을 제거할 수 있습니다.

그런 다음 키-값 교환을 다시 수행하고 키와 값을 다시 교환하여 중복 제거를 완료하세요.

<?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 &#39;unique count:&#39;.count($arr).&#39;<br>&#39;;
echo &#39;run time:&#39;.(float)(($endtime-$starttime)*1000).&#39;ms<br>&#39;;
echo &#39;use memory:&#39;.getUseMemory();
/**
 * 获取使用内存
 * @return float
 */
function getUseMemory(){
    $use_memory = round(memory_get_usage(true)/1024,2).&#39;kb&#39;;
    return $use_memory;
}
/**
 * 获取microtime
 * @return float
 */
function getMicrotime(){
    list($usec, $sec) = explode(&#39; &#39;, microtime());
    return (float)$usec + (float)$sec;
}
?>
unique count:99
run time:12.840032577515ms
use memory:768kb

array_flip 방식을 사용하여 중복을 제거하면 실행 시간은 약 18ms가 걸리며 메모리 사용량은 약 2m입니다.

그래서 array_flip 방식을 사용하여 중복 제거를 수행하는 것이 array_unique 방식을 사용하는 것보다 98% 짧으며 메모리 사용량은 4/5;

위 내용은 PHP에서 중복 데이터를 빠르게 제거하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.