ArrayList和LinkedList

ArrayList和LinkedList在性能上各有优缺点,都有各自所适用的地方,总的说来能够描述以下: 
1.对ArrayList和LinkedList而言,数组

  • 在列表末尾增长一个元素所花的开销都是固定的。
  • 对ArrayList而言,
    • 主要是在内部数组中增长一项,
    • 指向所添加的元素,
    • 偶尔可能会致使对数组从新进行分配;
  • 而对LinkedList而言,
    • 这个开销是统一的,
    • 分配一个内部Entry对象。

2.在ArrayList的中间插入或删除一个元素性能

  • 意味着这个列表中剩余的元素都会被移动;
  • 而在LinkedList的中间插入或删除一个元素的
    • 开销是固定的。

3.LinkedList不支持高效的随机元素访问。
4.ArrayList的空间浪费主要体如今在list列表的结尾预留必定的容量空间,对象

  • 而LinkedList的空间花费则体如今它的每个元素都须要消耗至关的空间

能够这样说:当操做是在一列数据的后面添加数据而不是在前面或中间,而且须要随机地访问其中的元素时,使用ArrayList会提供比较好的性能;List

  • 当你的操做是在一列数据的前面或中间添加或删除数据,而且按照顺序访问其中的元素时,就应该使用LinkedList了。
相关文章
相关标签/搜索