ArrayList类和LinkedList类对比分析

本文对比分析了ArrayList和LinkedList两种Java集合类。ArrayList基于数组实现,适合随机访问,而LinkedList采用双向链表结构,更适合于频繁的插入和删除操作。两者的初始化方式不同,ArrayList在构造函数中分配初始容量的数组,LinkedList则通过节点链接实现。在并发环境下,两者都需要通过同步手段保证线程安全。
摘要由CSDN通过智能技术生成

ArrayList类和LinkedList类对比分析

1.ArrayList类:

ArrayList是一个可以处理变长数组的类型,它是一个泛型类,可以存放任意类型的对象。顾名思义,ArrayList是一个数组列表,因此其内部是使用一个数组来存放对象的。ArrayList类常用的方法有add()、clear()、get()、indexOf()、remove()、sort()、toArray()、toString()等。ArrayList内部有一个私有类实现Iterator接口,因此可以使用iterator()方法得到ArrayList的迭代器。同时,还有一个私有类实现ListIterator接口,因此Array也可以调用listIterator()方法得到ListIterator迭代器。

2.LinkedList类

LinkedList可以看成一个双向链表,所有的操作都可以认为是一个双向链表的操作,因为它实现了Deque接口和List接口。同样,LinkedList也是线程不安全的,如果在并发环境下使用它,同样用Colletions类中的静态方法synchronizedList()对linkedList进行调用即可。

3.ArrayList类和LinkedList类实现方式对比

(1)存储方式对比

private static class Entry<E> {
	//当前节点对应值
	E element;
	//下一个节点
	Entry<E> next;
	//上一个节点
	Entry<E> previons;
	Entry(E element, Entry<E> next, Entry<E> previons) {
		this.element = element;
		this.next = next;
		this.previons = previons;
	}
}

(2)初始化对比
不论是ArrayList对象还是LinkedList对象都可以通过new关键字创建,它们的初始化主要还是在构造函数中进行。

private transient Object[] elementData;
private int size;
public ArrayList(int initialCapacity) {
	super();
	if(initialCapacity<0) {
		throw new IllegalArgumentException("Illega Capacity:"+initialCapacity);
	}
	this.elementData = new Object[initialCapacity];
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值