List接口:
看List的介绍,有序的 collection(也称为序列),此接口的用户可以对列表中每个元素的插入位置进行精确地控制(有下标)!用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素!与 set 不同,列表通常允许重复的元素!
//特点:
① 有序序列(怎么存进去可以怎么取出来)!
② 有下标,可以精确控制内部元素!
③ 允许存在重复元素,可以通过equals方法比较重复元素!
//List接口的子类:
① ArrayList集合
② LinkedList集合
List接口:
① add(Object e):向集合末尾处,添加指定的元素!
② add(int index, Object e):向集合指定索引处,添加指定的元素,原有元素依次后移!
③ remove(Object e):将指定元素对象,从集合中删除,返回值为被删除的元素!
④ remove(int index):将指定索引处的元素,从集合中删除,返回值为被删除的元素!
⑤ set(int index, Object e):将指定索引处的元素,替换成指定的元素,返回值为替换前的元素(Set前提必须有这个下标)!
⑥ get(int index):获取指定索引处的元素,并返回该元素!
Iterator并发修改异常:
//示例代码:
public class IteratorDemo {
//在list集合迭代元素中,对元素进行判断,一旦条件满足就添加一个新元素
1 public static void main(String[] args) { 2 3 //创建List集合 4 5 List<String> list = new ArrayList<String>(); 6 7 //给集合中添加元素 8 9 list.add("abc1"); 10 11 list.add("abc2"); 12 13 list.add("abc3"); 14 15 list.add("abc4"); 16 17 //迭代集合,当有元素为"abc2"时,集合加入新元素"a" 18 19 Iterator<String> it = list.iterator(); 20 21 while(it.hasNext()){ 22 23 String str = it.next(); 24 25 //判断取出的元素是否是"abc2",是就添加一个新元素 26 27 if("abc2".equals(str)){ 28 29 list.add("a");// 该操作会导致程序出错 30 31 } 32 33 } 34 35 //打印容器中的元素 36 37 System.out.println(list); 38 39 } 40 41 }
//运行上述代码发生了错误 java.util.ConcurrentModificationException[L1] (并发修改异常)
// Iterator和增强for在遍历集合的时候不允许操作元素
//在迭代器中可以用ListIterator对元素进行操作(重要)
List集合存储数据的结构:
堆栈/队列/数组/链表
//堆栈特点:
① 先进后出(存进去的元素,要在它后面的元素依次取出后,才能取出该元素)
② 栈的入口,出口的都是栈的顶端位置
③ 压栈:就是存元素(把元素存储到栈的顶端位置,栈中已有元素依次向栈底方向移动一个位置)
④ 弹栈:就是取元素(把栈的顶端位置元素取出,栈中已有元素依次向栈顶方向移动一个位置)
//队列特点:
① 先进先出(存进去的元素,要在后它前面的元素依次取出后,才能取出该元素)!
② 队列的入口,出口各占一侧!
//数组特点:
① 查找元素快:通过索引,可以快速访问指定位置的元素
② 增删元素慢:
指定索引位置增加元素:需要创建一个新数组,将指定新元素存储在指定索引位置,再把原数组元素根据索引,复制到新数组对应索引的位置
指定索引位置删除元素:需要创建一个新数组,把原数组元素根据索引,复制到新数组对应索引的位置,原数组中指定索引位置元素不复制到新数组中
(Tips:ArrayList底层是数组)
//链表特点:多个节点之间,通过地址进行连接!
① 查找元素慢:想查找某个元素,需要通过连接的节点,依次向后查找指定元素!
② 增删元素快:
增加元素:操作如左图,只需要修改连接下个元素的地址即可!
删除元素:操作如右图,只需要修改连接下个元素的地址即可!
总结:ArrayList和LinkedList集合
① ArrayList集合数据存储的结构是数组结构!元素增删慢,查找快,由于日常开发中使用最多的功能为查询数据、遍历数据,所以ArrayList是最常用的集合
① LinkedList集合数据存储的结构是链表结构!方便元素添加、删除的集合,实际开发中对一个集合元素的添加与删除经常涉及到首尾操作,而LinkedList提供了大量首尾操作的方法
//因材而用:查询较多用ArrayList,增删较多用LinkedList
LinkedList提供的方法:
Vector集合:
elements()方法相当与Iterator调用iterator()方法返回的迭代器对象!
枚举:
//Vector集合对ArrayList集合使用的对比—相当于早期的ArrayList,枚举就是早期的Iterator迭代器,所以稍作了解即可。