集合(二)

文章详细介绍了ArrayList、LinkedList和Vector这三个List接口的实现类。ArrayList效率高但不安全,底层基于数组,JDK8时延迟初始化。LinkedList适合频繁插入删除,基于双向链表,所有操作按链表形式执行。Vector线程安全但效率低,扩容为原来两倍。文中通过代码示例对比了它们在插入和查询大量数据时的性能差异。
摘要由CSDN通过智能技术生成

接着上一部分的Collection的知识
一.List接口
List接口是存储有序,可重复的数据

List接口的子类概述
ArrayList是作为List的主要实现类;效率高,但是不安全;底层使用的是Object[] 数组存储的
LinkedList是对于频繁的插入和删除操作,使用LinkedList的效率比ArrayList的效率高;底层使用的是双向链表存储的
Vector作为List接口的古老实现类,线程是安全的,效率低,底层使用的Object[]类

1.ArrayList
在JDK7.0的时候,ArrayList在底层创建了一个长度为10的Object[]数组。在添加的数组容量不够的时候,就会进行扩容,并且扩容为原来的1.5倍,同时复制到一个新的数组中去.但是在JDK8.0之后并没有在初始化的时候创建数组的长度而是在第一次调用的时候才创建的数组
JDK8.0比JDK7.0的时候优点是:延迟数组的创建,节省内存

2.LinkedList
LinkedList list= new Listedlist();内部声明为Node类型的first和last属性,默认值为null.其所有的操作都是按照双重链表的形式执行的

3.Vector
底层创建的是长度为10的数组,在扩容方面是扩容为原来的2倍.

4.ArrayList和LinkedList之间的效率比较

public static void main(String[] args) {
		// 创建集合
		ArrayList<String> arrayList = new ArrayList<String>();
		LinkedList<String> linkedList = new LinkedList<String>();

		// 调用方法存储数据
		long startTime = System.currentTimeMillis();
		insertData(linkedList, 100000);
		Long endTime = System.currentTimeMillis();
		System.out.println("linkedList插入数据所消耗的时间是:" + (endTime - startTime));
		// 调用方法存储数据
		long startTime1 = System.currentTimeMillis();
		insertData(arrayList, 100000);
		Long endTime1 = System.currentTimeMillis();
		System.out.println("arrayList插入数据所消耗的时间是:" + (endTime1 - startTime1));
		


		// 调用方法存储数据
		long startTime2 = System.currentTimeMillis();
		selectData(linkedList, 10000);
		Long endTime2 = System.currentTimeMillis();
		System.out.println("linkedList查询数据所消耗的时间是:" + (endTime2 - startTime2));
		// 调用方法存储数据
		long startTime3 = System.currentTimeMillis();
		selectData(linkedList, 10000);
		Long endTime3 = System.currentTimeMillis();
		System.out.println("arrayList查询数据所消耗的时间是:" + (endTime3 - startTime3));
	}

	/**
	 * 向List集合中添加数据
	 * 
	 * @param list  目标集合
	 * @param count 数据量
	 */
	public static void insertData(List<String> list, int count) {
		for (int i = 0; i < count; i++) {
			// 每一次都把数组插入到集合的中间
			list.add(0, "张三" + i);
		}
	}

	/**
	 * 从List集合中查询数据
	 * @param list   目标集合
	 * @param count  查询量
	 */
	public static void selectData(List<String> list, int count) {
		for (int i = 0; i < count; i++) {
			// 每一次查询中间的元素
			list.get(list.size() / 2);
		}

	}

简答题
1.ArrayList,LinkedList,和Vector三者之间的异同
相同点:三个类都实现了List接口,存储数据的特点相同,有序 ,可重复的数据
不同点:将上面的表格

2.区分remove(int index)和remove(Object obj)两者之间的区别
remove(int index)移除列表中指定位置的元素
remove(Object obj)移除列表中第一次出现的指定元素,如果数据存在的话

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值