Java List集合知多少?

List集合在开发中可谓是最经常使用的了,从第一次使用到“爱不释手”。有用的没用的都整理了一下。
这里写图片描述

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值