8.5.4 各种线性表的性能分析

8.5.4 各种线性表的性能分析

线性表

Java提供的List就是一个线性表接口,而ArrayListLinkedList又是线性表的两种典型实现:基于数组的线性表基于链表的线性表

队列

Queue代表了队列

双端队列

Deque代表了双端队列(既可作为队列使用,也可作为栈使用),接下来对各种实现类的性能进行分析。

初学者可以无须理会ArrayListLinkedList之间的性能差异,只需要知道LinkedList集合不仅提供了List的功能,还提供了双端队列* 、*栈 的功能**就行。但对于一个成熟的Java程序员,在一些性能非常敏感的地方,可能需要慎重选择哪个List实现。

数组 随机访问性能好

一般来说,由于数组以一块连续内存区来保存所有的数组元素,所以数组在随机访问时性能最好,所有的内部以数组作为底层实现的集合在随机访问时性能都比较好;

链表 插入 删除操作性能好

内部以链表作为底层实现的集合在执行插入删除操作时有较好的性能。

优先考虑使用ArrayList

但总体来说, ArrayList的性能比LinkedList的性能要好,因此大部分时候都应该考虑使用ArrayList.

List集合使用建议

应该使用随机访问方法get()来遍历ArrayList

对于ArrayListVector集合,应该使用随机访问方法(也就是get())来遍历集合元素,这样性能更好;

应该使用迭代器遍历LinkedList

对于LinkedList集合,则应该采用迭代器(Iterator)来遍历集合元素.

频发插入 删除时使用LinkedList

如果需要经常执行插入删除操作来改变包含大量数据的List集合的大小,可考虑使用LinkedList集合。
使用ArrayListVector集合可能需要经常重新分配内部数组的大小,效果可能较差。

Collections功能将List集合变成线程安全

如果有多个线程需要同时访问List集合中的元素,开发者可考虑使用Collections将集合包装成线程安全的集合。