1、集合的继承体系
2、集合的最高接口:
java.util.Collection
- 子接口List:
可以重复,有先后顺序,有索引值。
常用子类:ArrayList/LinkedList/Vector - 子接口Set:
不能重复,不保证先后顺序,没有索引值。
常用子类:TreeSet/HashSet/LinkedHashSet
3、集合概述
- 数组和集合都是一种容器,都可存储多个数据。
- 数组长度不可改变,但大多数集合可以改变。
- 数组中类型必须统一,集合中“可选统一”。
- 若在使用集合时,未写泛型,则会存储Object类型。(下面还有泛型擦除的问题)
4、集合的常用方法
public boolean add(E e) : 把给定的对象添加到当前集合中 。
public void clear() :清空集合中所有的元素。
public boolean remove(E e) : 把给定的对象在当前集合中删除。
public boolean contains(E e) : 判断当前集合中是否包含给定的对象。
public boolean isEmpty() : 判断当前集合是否为空。
public int size() : 返回集合中元素的个数。
public Object[] toArray() : 把集合中的元素,存储到数组中。
5、迭代器
在程序开发中,经常需要遍历集合中的所有元素。针对这种需求,JDK专门提供了一个接口java.util.Iterator 。 Iterator 接口也是Java集合中的一员,但它与 Collection 、 Map 接口有所不同,Collection 接口与 Map 接口主要用于存储元素,而 Iterator 主要用于迭代访问(即遍历) Collection 中的元
素,因此 Iterator 对象也被称为迭代器。
1、获取方法:
public Iterator iterator() : 获取集合对应的迭代器,用来遍历集合中的元素的。
2、常用方法:
public E next() :返回迭代的下一个元素。(读字符串并向后移位)
public boolean hasNext() :如果仍有元素可以迭代,则返回 true
tips:在进行集合元素取出时,如果集合中已经没有元素了,还继续使用迭代器的next方法,将会发生java.util.NoSuchElementException没有集合元素的错误。
3、迭代器不可直接生成,要通过
Iterator<String> iter = 集合.iterator();
while (iter.hasNext()) {
System.out.println(iter.next());
}
生成。
tips:在使用迭代器时,不可直接改变集合个数,如下:
while (iter.hasNext()) {
System.out.println(iter.next());
集合.add("啦啦啦");
}
便只输出一个元素,然后报java.util.ConcurrentModificationException异常。
6、迭代器的使用原理
Iterator迭代器对象在遍历集合时,内部采用指针的方式来跟踪集合中的元素,为了让初学者能更好地理解迭代器的工作原理,接下来通过一个图例来演示Iterator对象迭代元素的过程:
7、迭代器并发修改异常
如上图所示:iterator是由集合生成的,所以如果在iterator生成之后修改集合,会报并发修改异常,直接采用fast fail,报废之前的iterator,并不会尝试修复。