组团学

List集合

阅读 (254730)

1、List概述

1.1、什么是List

java.util.List 接口继承自 Collection 接口,是单列集合的一个重要分支,习惯性地会将实现了 List 接口的对象称为List集合。在List集合中允许出现重复的元素,所有的元素是以一种线性方式进行存储的,在程序中可以通过索引来访问集合中的指定元素。

List集合中元素有序,即元素的存入顺序和取出顺序一致。

1.2、List特点

List是一个元素存取有序的集合。例如,存元素的顺序是11、22、33。那么集合中,元素的存储就是按照11、 22、33的顺序完成的

List是一个带有索引的集合,通过索引就可以精确的操作集合中的元素(与数组的索引是一个道理)

List中可以有重复的元素,通过元素的equals方法,来比较是否为重复的元素

1.3、List子类

ArrayList:底层数据结构是数组结构。线程不安全的。所以ArrayList的出现替代了Vector。增删慢,查找快。

LinkedList:底层是链表数据结构。线程不安全的,同时对元素的增删快,查找慢。

Vector:底层数据结构是数组结构。jdk1.0版本。线程安全的。无论增删还是查询都非常慢,已被ArrayList替代。

2、List常用方法

void add(int index, E element) //指定索引添加元素

E remove(int index) //移除指定索引处元素

E get(int index) //获取指定索引元素

E set(int index, E element) //修改指定索引元素

List <E> subList(int fromIndex, int toIndex) //截取指定索引子集

int indexOf(Object o) //返回指定元素索引位置

import java.util.ArrayList; import java.util.List; public class ListDemo01 { public static void main(String[] args) { fun3(); fun2(); fun(); } private static void fun3() { List<String> al = new ArrayList<>(); al.add("111");// 添加 Collection中 继承来的 al.add("222"); al.add("333"); al.add("444"); System.out.println(al); //修改指定索引元素 al.set(2, "6666"); System.out.println(al); //修改指定索引元素 List<String> subList = al.subList(1, 4); System.out.println(subList); //返回指定元素索引位置 int indexOf = subList.indexOf("444"); System.out.println(indexOf); } private static void fun2() { List<Integer> al = new ArrayList<>(); al.add(1); al.add(2); al.add(3); al.add(4); //移除指定索引处元素 al.remove(2); System.out.println(al); //获取指定索引元素 System.out.println(al.get(2)); } private static void fun() { List<String> al = new ArrayList<>(); al.add("111");// 添加 Collection中 继承来的 al.add("222"); al.add("333"); al.add("444"); //指定索引添加元素 al.add(2, "666"); al.add(5, "999"); al.add(6, "000999"); System.out.println(al); //移除指定索引处元素 al.remove(6); System.out.println(al); } }

ListIterator <E> listIterator() 注意:用于应对并发修改异常的返回迭代器方法与迭代器

import java.util.*; public class ListDemo02 { public static void main(String[] args) { fun(); fun1(); } private static void fun() { Collection c= new ArrayList(); c.add("孙悟空"); c.add("白骨精"); c.add("唐三藏"); c.add("八戒"); //遍历 集合, 如果 包含 白骨精 ,你就添加一个 白龙马. Iterator iterator = c.iterator(); while(iterator.hasNext()) { Object object = (Object) iterator.next(); if (object.equals("白骨精")) { // c.add("白龙马"); //ConcurrentModificationException } } System.out.println(c); } private static void fun1(){ List c = new ArrayList(); c.add("孙悟空"); c.add("白骨精"); c.add("唐三藏"); c.add("八戒"); ListIterator li= c.listIterator(); while (li.hasNext()) { Object object = (Object) li.next(); if (object.equals("白骨精")) { li.add("白龙马"); } } System.out.println(c); while (li.hasPrevious()) { System.out.print(li.previous() + " "); } System.out.println(); ListIterator listIterator = c.listIterator(); System.out.println(listIterator.next()); //与hasNext()相反,往前遍历 System.out.println(listIterator.hasPrevious()); } }
需要 登录 才可以提问哦