2017-03-15-Java基础-List介绍

ArrayList Vector LinkedList的区别及其优缺点

一,特点

1,ArrayList,LinkedList,Vector这三个类都实现了java.util.List接口,但它们有各自不同的特性

2,ArrayList Vector内部实现都是数组,LinkedList是一个双向列表

3,LinkedList 是基于链表结构实现,所以在类中包含了 first 和 last 两个指针(Node)。Node 中包含了上一个节点和下一个节点的引用,这样就构成了双向的链表。每个 Node 只能知道自己的前一个节点和后一个节点,但对于链表来说,这已经足够了。

4,Vector是线程安全的,适合多线程下的编程。ArrayList,LinkedList是线程不安全的,适合单线程下的编程。因此Vector的操作比ArrayList,LinkedList开销要大

5,LinkedList适合增删操作,因为只需要改变指针,而查询某个元素必须从第一个开始,因此时间复杂度是O(n)。ArrayList 适合查询操作,查询某个元素的时间复杂度是O(1);

二, 如何有效的遍历一个list

1,enhanced for loop是编译的时候变成了使用iterator去调用。会创建垃圾的。但是却不可以用来做添加删除操作。

2,如果是ArrayList的话,直接用普通的for循环最好。

3,如果是LinkedList,不确定size的话可以先判断size是否大于0,

4,有删除添加操作的话就直接用iterator

5,使用普通的 for loop去遍历linkedList效率是很低的

6,list的遍历:

推荐使用普通的For Loop访问时间是O(1),不会创建任何对象

LinkedList,推荐使用Enhanced for loop

对于未知的List泛型,使用Enhanced for loop,性能最好

LinkedList适用于频繁的增删操作的情况

三,Iterator和ListIterator的区别

最近看到集合类,知道凡是实现了Collection接口的集合类,都有一个Iterator方法,用于返回一个实现了Iterator接口的对象,用于遍历集合;(Iterator接口定义了3个方法分别是hasNext(),next(),remove();)

我们在使用List,Set的时候,为了实现对其数据的遍历,我们经常使用到了Iterator(迭代器)。使用迭代器,你不需要干涉其遍历的过程,只需要每次取出一个你想要的数据进行处理就可以了。

但是在使用的时候也是有不同的。List和Set都有iterator()来取得其迭代器。对List来说,你也可以通过listIterator()取得其迭代器,两种迭代器在有些时候是不能通用的,Iterator和ListIterator主要区别在以下方面:

1. iterator()方法在set和list接口中都有定义,但是ListIterator()仅存在于list接口中(或实现类中);

2. ListIterator有add()方法,可以向List中添加对象,而Iterator不能

3. ListIterator和Iterator都有hasNext()和next()方法,可以实现顺序向后遍历,但是ListIterator有hasPrevious()和previous()方法,可以实现逆向(顺序向前)遍历。Iterator就不可以。

4. ListIterator可以定位当前的索引位置,nextIndex()和previousIndex()可以实现。Iterator没有此功能。

5. 都可实现删除对象,但是ListIterator可以实现对象的修改,set()方法可以实现。Iierator仅能遍历,不能修改。

因为ListIterator的这些功能,可以实现对LinkedList等List数据结构的操作。其实,数组对象也可以用迭代器来实现。

你可能感兴趣的:(2017-03-15-Java基础-List介绍)