我们为什么需要Collection接口、List接口与Set接口?
Collection接口是List接口与Set接口的父类接口,而各个集合的又是List接口与Set接口的实现类。虽然是三个父类接口,接口中方法具体的实现在子类,但对接口的掌握,可以提高我们对集合的全局认识。
Collection接口
Collection接口中定义的全部抽象方法如下:
这里列举说明一些常用的方法:
方法 | 说明 |
---|---|
boolean add(E e) | 添加元素到容器中 |
boolean remove(Object o) | 从容器中移除元素 |
boolean contains(Object o) | 判断容器是否包含该元素 |
int size() | 返回容器中元素的数量 |
boolean isEmpty() | 判断容器是否为空 |
void clear() | 清空容器中所有元素 |
Iterator iterator() | 获取迭代器,用于遍历容器 |
boolean containsAll(Collection<?> c) | 判断本容器是否包含目标容器所有元素 |
boolean addAll(Collection<? extends E> c) | 将目标容器所有元素添加到本容器 |
boolean removeAll(Collection<?> c) | 移除本容器中,与目标容器元素的交集 |
boolean retainAll(Collection<?> c) | 只保留本容器与目标容器元素的交集 |
Object[] toArray() | 转化为数组 |
List接口
List是有序、可重复的容器。List接口继承于Collection接口。
- 有序:List中每个元素都有索引标记。可以根据元素的索引标记(在List中的位置)访问元素,从而精确控制这些元素。
- 可重复:List允许加入重复的元素。更确切地讲,List通常允许满足 e1.equals(e2) 的元素重复加入容器。
List接口中的所有抽象方法如下:
对比Collection接口,List接口主要额外声明了一些跟顺序(索引、下标)有关的方法,如下:
方法 | 说明 |
---|---|
void add(int index, E element) | 在指定位置插入元素 |
E set(int index, E element) | 修改指定位置的元素 |
E get(int index) | 返回指定位置的元素 |
E remove(int index) | 移除指定位置的元素 |
int indexOf(Object o) | 返回第一个匹配元素的索引,若无该元素则返回-1 |
int lastIndexOf(Object o) | 返回最后一个匹配元素的索引,若无该元素则返回-1 |
List接口常用的实现类有3个:ArrayList、LinkedList和Vector。
Collection接口与List接口都无法实例化,这里用平时使用较多的ArrayList实现类,来具体测试一下Collection接口与List接口接口中的方法:
//测试add/remove/size/isEmpty/contains/clear/toArrays等方法
public class Test {
public static void main(String args[]) {
List<String> list = new ArrayList<String>(); //多态,子类对象,赋值给父类类型
System.out.println(list.isEmpty()); // true,容器里面没有元素
list.add("a");
System.out.println(list.isEmpty()); // false,容器里面有元素
list.add("b");
list.add("c");
System.out.println(list);
System.out.