pecl install ds
brew install homebrew/php/php71-ds
目前PHP7.2不支持使用 brew 安装。php
Array
PHP5.x 的时代,Array
是惟一的表示集合的数据类型,在 PHP 中,他既是 List 也是 Map, 他就是一切。前端
<?php $a = array(1,2,3,4); $b = array('a'=>1,'b'=>2,'c'=>3);
这种数据类型的确是给开发者带来了便捷性,但让PHPer 会主键的忽略掉数据结构带来的好处,特别是在学习其余的语言时,给PHPer 带来困扰。git
在 PHP 升级到7后,Array
也同时获得了优化,可是他的结构并无发生变化, “optimised for everything; optimised for nothing” with room for improvement。那若是咱们能够经过引入更便利的数据结构优化性能,同时写代码反而更方便了,那何乐而不为呢?github
“SPL数据结构怎么样?”
Unfortunately they are terrible. They did offer some benefits prior to PHP 7, but have since been neglected to the point of having no practical value.“咱们为何不能修正和改进它们?”
We could, but I believe their design and implementation is so poor that it would be better to replace them with something brand new.shell“SPL数据结构的设计很是可怕。” - 安东尼 费拉拉json
<?php $a = []; $a['a']; // PHP Notice: Undefined offset
通常的 PHPer 都不会用array_key_exists 和 if else 来处理,这样作会显得有些麻烦。vim
PHP 内部实际上是经过建立新的 array 来完成 array_unshift 操做的,其性能问题可想可知。数组
DataStructures,PHP7的一个扩展,数组(Array)的一个替代品。php7
Github: https://github.com/php-ds数据结构
Namespace: Ds\
接口类: Collection, Sequence, Hashable
实现类(final class): Vector, Deque, Map, Set, Stack, Queue, PriorityQueue, Pair
Sequence 是类数组数据结构的基础接口,定义了不少重要且方便的方法,好比 contains, map, filter, reduce, find, first, last 等。从图中可知,Vector, Deque, Stack, Queue 都直接或者间接的实现了这个接口。它的特色以下:
优势:
缺点:
PhotoShop中使用主要的数据结构就是 Vector ---- Sean Parent
两个指针用于跟踪头部和尾部, 指针能够“wrap around”缓冲区的末尾,这避免了须要移动其余值来腾出空间。 这使得移位和移位很是快 - Vector没法与之竞争。视频说明
优势:
缺点:
hashTable
。Hashable只引入了两种方法:hash和equals。支持Hashable接口的数据结构是Map和Set。Map , 一种连续的键值对集合。同 array 的使用是一致的,key 但是是任意的类型,可是必须惟一。若是相同的 key 添加到 Map 中,那么会替换掉原有的。同array 同样,插入的顺序会被保留。
优势:
缺点:
Set,是一个无序惟一值的集合。Map 内部使用了 set 的实现,他们都是基于Array 相同的内部结构,这意味这Set 的排序具备 O(n*log n) 的复杂度。
优势:
缺点:
这里在说明一点,Array中的值自己是没有索引的,所以在使用 in_array()
的时候呈线性搜索,复杂度为 O(n)。
若是想要建立一个惟一值数组,可使用 array_unique()
,因为array_unique()
针对的是 value 而不是 key,因此每一个数组成员都会被限行搜索,复杂度会变为 O(n²)。