资讯专栏INFORMATION COLUMN

【译】更快的方式实现PHP数组去重

岳光 / 3278人阅读

摘要:原文来自原文概述使用的函数允许你传递一个数组,然后移除重复的值,返回一个拥有唯一值的数组。有一个比较好而且更快的函数来替代使用函数来创建唯一的数组。

原文来自: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()函数允许你传递一个数组,然后移除重复的值,返回一个拥有唯一值的数组。这个函数大多数情况下都能工作得很好。但是,如果你尝试在一个大的数组里使用array_unique()函数,它会运行地慢一些。

有一个比较好而且更快的函数array_flip()来替代使用array_unique()函数来创建唯一的数组。这个魔法般的函数会交换数组里面每一个元素的键和值,因为键值必须唯一,因此,你会得到跟array_unique()函数一样的结果。

更快的方式实现PHP数组去重
/* 创建一个包含重复值的,一共四个元素的数组 */
$array = array("green","blue","orange","blue");

/* 翻转数组,你将会得到唯一键值的数组
        array("green"=>0,"blue"=>1,"orange"=>2); */
$array = array_flip($array);

/* 然后再翻转一次,将键和值重新放置,然后得到数组:array(0=>"green",1=>"blue",2=>"orange"); */
$array = array_flip($array);

因为我们已经移除了一些元素,因此数组看起来不是正常的序列。比如我们可能会得到:array(0=>"A",2=>"B",5=>"C");。在某些情况下,这不是一个问题,但是如果你需要数组的键值保持数字的序列,你可以使用一到两种方法解决键值乱序的问题。

使用array_merge修复数组的keys

添加array_flip之后的函数,将会对数组的键值排序并且让它们恢复到正常的序列,如:0,1,2,3...

$array = array("green","blue","orange","blue");
$array = array_flip($array);
$array = array_flip($array);

/* 使用array_merge()函数修复键值*/
$array = array_merge($array);
第二种方式,使用array_keys

注意,这种修复数组键值的方法比使用array_merge()函数稍微快了一点。你也可以在最后一步结合使用array_keys()函数(此函数返回翻转后的值)。然后当你翻转数组的值,键值就会根据顺序创建。

$array = array("green","blue","orange","blue");
$array = array_flip($array);
/* 跟第一个例子一样,但是现在我们先提取数组的键值 */
$array = array_keys($array);
结论

非常简单,比起在大数组使用array_unique函数,有了一个有效的性能提升。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/21320.html

相关文章

  • 【性能为王】从PHP源码剖析array_keys和array_unique

    摘要:由于原文没有给出源码分析和测试的结果,导致给读者造成迷惑,在此说声抱歉。测试结果表明,使用后再调用函数比函数快。结论因为底层调用了快排算法,加大了函数运行的时间开销,导致整个函数的运行较慢。 文章来自:http://www.hoohack.me/2016/02/25/analyze-array-unique-array-keys-source-code 我在github有对PHP源码更...

    zollero 评论0 收藏0
  • 】JS基础算法脚本:类数组(arguments)去重

    摘要:参数用来测试数组的每个元素的函数。调用时使用参数。返回表示保留该元素通过测试,则不保留。执行时的用于的值。那些没有通过测试的元素会被跳过,不会被包含在新数组中。有其他好的方法或思路的道友,不妨在沙发区神交一番。 需求 给出一个类数组,删除要求的重复数据,返回新数组 destroyer([1, 2, 3, 1, 2, 3], 2, 3) should return [1, 1] dest...

    mrcode 评论0 收藏0
  • 前端面试题

    摘要:前端面试题总结,持续更新和区别浏览器的缓存机制提供了可以将用户数据存储在客户端上的方式,可以利用等跟服务端进行数据交互。 前端面试题总结,持续更新 cookies sessionStorage和localstorage区别 浏览器的缓存机制提供了可以将用户数据存储在客户端上的方式,可以利用cookie,session等跟服务端进行数据交互。相同点:都是存储在客户端不同点:showI...

    raledong 评论0 收藏0
  • 前端面试题

    摘要:前端面试题总结,持续更新和区别浏览器的缓存机制提供了可以将用户数据存储在客户端上的方式,可以利用等跟服务端进行数据交互。 前端面试题总结,持续更新 cookies sessionStorage和localstorage区别 浏览器的缓存机制提供了可以将用户数据存储在客户端上的方式,可以利用cookie,session等跟服务端进行数据交互。相同点:都是存储在客户端不同点:showI...

    seal_de 评论0 收藏0
  • 前端面试题

    摘要:前端面试题总结,持续更新和区别浏览器的缓存机制提供了可以将用户数据存储在客户端上的方式,可以利用等跟服务端进行数据交互。 前端面试题总结,持续更新 cookies sessionStorage和localstorage区别 浏览器的缓存机制提供了可以将用户数据存储在客户端上的方式,可以利用cookie,session等跟服务端进行数据交互。相同点:都是存储在客户端不同点:showI...

    xiaoqibTn 评论0 收藏0

发表评论

0条评论

岳光

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<