Java List集合知多少?
2016-05-16 23:50
1176 查看
List集合在开发中可谓是最经常使用的了,从第一次使用到“爱不释手”。有用的没用的都整理了一下。
通用迭代器:
列表迭代器:
注:使用previous()方法的时候,需要先向后遍历,才能逆向遍历输出。
并发修改异常:
注:使用迭代器如果有类似写法也会出现并发修改异常。
常用方法:
常用方法:
注:更多方法查看API
1.基本概念
List:Collection集合的子接口,List是有序集合,允许元素重复,List中的元素都对应着一个整数型的序号,记载其在容器中的位置,可以根据序号存取容器中的元素。2.常用方法
(1).添加功能
// 向滚动列表的末尾添加指定的项 void add(String item) // 向滚动列表中索引指示的位置添加指定的项 void add(String item, int index)
List list = new ArrayList(); // 添加元素 list.add("A"); // 添加元素并指定位置 list.add(1, "B"); list.add(0, "C"); // 添加自定义对象 list.add(new User("--", 11)); System.out.println(list);// [C, A, B, User [name=--, age=11]]
(2).删除功能
// 从此滚动列表中移除指定位置处的项 void remove(int position) // 从列表中移除项的第一次出现 void remove(String item) // 从此列表中移除所有项 void removeAll()
List list = new ArrayList(); // 添加 list.add("A"); // 添加元素并指定位置 list.add("B"); list.add("C"); list.add("B"); System.out.println(list);// [A, B, C, B] //根据index删除元素 list.remove(0); System.out.println(list);// [B, C, B] //根据元素对象删除元素 list.remove("B"); System.out.println(list);// [C, B] //删除全部元素 list.removeAll(list); System.out.println(list);// []
(3).获取功能
// 获取与指定索引关联的项 Object list.get(int index) // 获取列表中的项 int list.size();
List list = new ArrayList(); // 添加 list.add("A"); // 添加元素并指定位置 list.add("B"); list.add("C"); list.add("B"); System.out.println(list.get(0));// A System.out.println(list.get(3));// B System.out.println(list.size());// 4
(4).修改功能
// 用指定元素替换列表中指定位置的元素 // E set(int index, E element)
List<String> list = new ArrayList<String>(); // 添加 list.add("A"); // 添加元素并指定位置 list.add("B"); list.add("B"); System.out.println(list);// [A, B, B] // 替换位置index为2的元素 list.set(2, "C"); System.out.println(list);// [A, B, C]
(5).迭代器使用
图示:通用迭代器:
//如果仍有元素可以迭代,则返回true boolean hasNext() //返回迭代的下一个元素 E next() //从迭代器指向的collection中移除迭代器返回的最后一个元素 void remove()
List list = new ArrayList(); // 添加 list.add("A"); // 添加元素并指定位置 list.add("B"); list.add("C"); list.add("D"); // 普通迭代器 Iterator iterator = list.iterator(); while (iterator.hasNext()) { System.out.println(iterator.next());// ABCD } // 删除一个元素 iterator.remove(); System.out.println(list);// ABC
列表迭代器:
// 将指定的元素插入列表 void add(E e) // 以正向遍历列表时,如果列表迭代器有多个元素,则返回true boolean hasNext() // 如果以逆向遍历列表,列表迭代器有多个元素,则返回true boolean hasPrevious() // 返回列表中的下一个元素 E next() // 返回对next的后续调用所返回元素的索引 int nextIndex() // 返回列表中的前一个元素 E previous() // 返回对previous的后续调用所返回元素的索引 int previousIndex() // 从列表中移除由next或previous返回的最后一个元素 void remove() // 用指定元素替换next或previous返回的最后一个元素 void set(E e)
List list = new ArrayList(); // 添加 list.add("A"); // 添加元素并指定位置 list.add("B"); list.add("C"); list.add("D"); // 列表迭代器 ListIterator listIterator = list.listIterator(); while (listIterator.hasNext()) { System.out.print(listIterator.next());// ABCD } while (listIterator.hasPrevious()) { //返回列表中的前一个元素 System.out.println(listIterator.previous());// DCBA }
注:使用previous()方法的时候,需要先向后遍历,才能逆向遍历输出。
并发修改异常:
// 并发修改异常 List list = new ArrayList(); // 添加 list.add("A"); // 添加元素并指定位置 list.add("B"); list.add("C"); list.add("D"); // java.util.ConcurrentModificationException for (Object object : list) { // 这里改变了集合 相对于改变了循环条件,所以有异常 list.remove(0); }
注:使用迭代器如果有类似写法也会出现并发修改异常。
3.遍历集合
(1)使用获取方法
List list = new ArrayList(); // 添加 list.add("A"); // 添加元素并指定位置 list.add("B"); list.add("C"); list.add("D"); for (int i = 0; i < list.size(); i++) { String str = (String) list.get(i); System.out.print(" " + str);// A B C D }
(2)使用迭代器
ListIterator iterator = list.listIterator(); while (iterator.hasNext()) { String str = (String) iterator.next(); System.out.print(" " + str);// A B C D }
(3)使用增强for
for (Object object : list) { String str = (String) object; System.out.print(" " + str);// A B C D }
4.*主要实现类
(1)ArrayList:
是线性顺序存储的,是一种线性表,可以存储重复数据,可以看成动态数组。底层数据结构是数组,查询快,增删慢。线程不安全,效率高。(2)LinkedList:
List接口的链接列表实现底层数据结构是链表,查询慢,增删快。线程不安全,效率高。常用方法:
添加方法: // 将指定元素插入此列表的开头 void addFirst(E e) // 将指定元素添加到此列表的结尾 void addLast(E e) 删除方法: // 移除并返回此列表的第一个元素 E removeFirst() // 移除并返回此列表的最后一个元素 E removeLast() 获取方法: // 返回此列表的第一个元素。 E getFirst() // 返回此列表的最后一个元素 E getLast()
LinkedList<String> linkedList = new LinkedList<String>(); // 添加到集合最开头 linkedList.addFirst("A"); linkedList.add("B"); // 添加到集合最末尾 linkedList.addLast("C"); System.out.println(linkedList);// [A, B, C] linkedList.removeFirst(); linkedList.removeLast(); System.out.println(linkedList);// [B] System.out.println(linkedList.getFirst());// B System.out.println(linkedList.getLast());// B
(3)Vector:
动态数组,可以根据需要动态伸缩。底层数据结构是数组,查询快,增删慢。线程安全,效率低。常用方法:
添加方法: // 将指定的组件添加到此向量的末尾,将其大小增加 1 void addElement(E obj) 删除方法: // 从此向量中移除全部组件,并将其大小设置为零 void removeAllElements() // 从此向量中移除变量的第一个(索引最小的)匹配项 boolean removeElement(Object obj) // 删除指定索引处的组件 void removeElementAt(int index) 获取方法: // 返回指定索引处的组件 E elementAt(int index) // 返回此向量的组件的枚举 Enumeration<E> elements() // 返回此向量的第一个组件 E firstElement() // 返回此向量的最后一个组件 E lastElement()
Vector<String> vector = new Vector<String>(); //添加元素 vector.addElement("A"); vector.addElement("B"); vector.addElement("C"); vector.addElement("D"); System.out.println(vector);//[A, B, C, D] //移除元素 vector.removeElementAt(0); vector.removeElement("D"); System.out.println(vector);//[B, C] System.out.println(vector.firstElement());//B System.out.println(vector.lastElement());//C // Enumeration类似于迭代器 Enumeration<String> element= vector.elements(); while (element.hasMoreElements()) { System.out.print(" "+element.nextElement());// B C }
注:更多方法查看API
相关文章推荐
- java.io.File的路径获取方式分析
- Add Two Numbers
- JAVA——OutputStream类和InputStream类
- Java多线程与并发(六)之线程池
- Java实现一个简单的租车系统
- Java实现蛇形举证_2
- 删除文件夹和复制文件夹 java
- java正则匹配及替换的一点思考
- java 位运算与运算基础
- 开发笔记--java.lang.OutOfMemoryError: PermGen space异常处理
- Struts2中通过超链接传参数要注意的问题
- SpringMVC添加spring-security静态资源加载问题
- java Cache框架
- Eclipse输入任意字母或指定字符出现提示框
- [javaSE] 数组(排序-冒泡排序)
- RxJava之调度器(Schedulers)
- java 面向对象练习题2
- JAVA实现数据库数据导入/导出到Excel(POI技术)
- C#和Java中的i=i++问题分析与备忘
- MyEclipse/Eclipse 优化