Hi i,m JinXiang
⭐ 前言 ⭐
本篇文章主要介绍java List集合的三种实现类ArrayList,LinkedList,Vector以及部分理论知识
🍉欢迎点赞 👍 收藏 ⭐留言评论 📝私信必回哟😁
🍉博主收将持续更新学习记录获,友友们有任何问题可以在评论区留言
目录
什么是List集合?
为什么要使用List集合
List集合的特点:
List集合总结:
ArrayList,LinkedList,Vector的相同点与区别:
使用List集合(实操)
1、ArrayList(增删改查)
2、LinkedList(增删改查)
3、Vector(增删改查)
什么是List集合?
ArrayList,LinkedList,Vector都是隶属于List集合的一种;
集合List
- List代表了有序可重复集合,可直接根据元素的索引来访问。
- List接口常用的实现类有:ArrayList、LinkedList、Vector。
为什么要使用List集合
List集合的特点:
集合中的元素允许重复
集合中的元素是有顺序的,各元素插入的顺序就是各元素的顺序
集合中的元素可以通过索引来访问或者设置
List集合总结:
1==):ArrayList
优点: 底层数据结构是数组,查询快,增删慢。
缺点: 线程不安全,效率高
2==):Vector
优点: 底层数据结构是数组,查询快,增删慢。
缺点: 线程安全,效率低
3==):LinkedList
优点: 底层数据结构是链表,查询慢,增删快。
缺点: 线程不安全,效率高
ArrayList,LinkedList,Vector的相同点与区别:
相同点:
- 1、ArrayList、Vector、LinkedList类均在java.util包中,均为可伸缩数组,即可以动态改变长 度的数组。
- 2、都有序,有索引,可重复。(此处的索引是可以通过索引查找该元素)
不同点:
1、ArrayList和Vector都是在内存中开辟连续内存来存储数据,有一个初始化的容量大小,可以通过序号来访问元素,虽然速度较快,但是插入元素时需要移动容器中的元素,所以对数据的插入操作比较麻烦。同时对储存空间进行动态的扩容时,为了提高效率,每次都是增加多个存储单元,Vector默认是原来的两倍,ArrayList是1.5倍。
Vector默认采用的是立即初始化容积值的操作,也可以设置初始化容积和步长值,构造器中只有一个初始化容积值,默认的扩容步长值为0
2、Array List和Vector最大的区别是synchronized的使用,Array List没有一个方法是同步的,而Vector的绝大多数的方法都是直接或者间接是同步的所以Vector线程是安全的,而Array List线程是不安全的。
Array List添加元素的add方法调用的是私有的add方法,进行扩容时是用size+1的方式,调用grow方法,再调用参数为minCapacity的newCapacity方法而remove删除方法则是调用的fastRemove方法
Vector中add方法与Array List基本相同,而remove方法调用的是removeElement方法 ,删除指定位置的元素再调用removeElementAt方法
3、LinkedList是采用双向列表来实现的,对数据的索引需要从列表头开始遍历,因此用于随机访问则效率比较低。但是插入元素时不需要对数据进行移动,因此插入效率较高。同时,LinkedList也是线程不安全的容器。
Linked List中的节点定义的是一个静态内部类;添加操做add调用的是linkLast方法,是在链表尾部添加数据,在指定位置新增数据,则针对索引需要进行合法性检查;查找指定元素的下标索引值用indexOf方法;删除指定位置上的元素用int类型参数的remove方法调用的是unlike方法。
使用List集合(实操)
1、ArrayList(增删改查)
import org.junit.Test;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Vector;
public class vector {
/**
* ArrayList的
* 增删改查操作
* */
@Test
public void ArrayList_Test(){
ArrayList arrayList = new ArrayList<>(); //默认空间10
//新增--添加一个数据
arrayList.add("HELLO WORLD!");
//新增--添加一个数据(在此列表中的指定位置插入指定的元素)
arrayList.add(1,"张三");
//删除--删除一个数据
arrayList.remove("你好");
//删除--删除一个数据(删除该列表中指定位置的元素)
arrayList.remove(1);
//删除--删除列表中所有数据
arrayList.clear();
//修改--修改一个数据(用指定的元素替换此列表中指定位置的元素)
arrayList.set(1, "李四");
//返回此列表中的元素数
arrayList.size();
//查看所有信息
System.out.println(arrayList);
}
}
2、LinkedList(增删改查)
import org.junit.Test;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Vector;
public class vector {
/**
* LinkedList的
* 增删改查操作
* */
@Test
public void LinkedList_Test(){
LinkedList linkedList = new LinkedList<>();
//新增--添加一个数据
linkedList.add("HELLO WORLD!");
//新增--添加一个数据(在此列表中的指定位置插入指定的元素)
linkedList.add(1,"张三");
//删除--删除一个数据
linkedList.remove("你好");
//删除--删除一个数据(删除该列表中指定位置的元素)
linkedList.remove(1);
//删除--但不删除此列表的头(第一个元素)
linkedList.element();
//删除--检索并删除此列表的头(第一个元素)
linkedList.poll();
//删除--删除列表中所有数据
linkedList.clear();
//修改--修改一个数据(用指定的元素替换此列表中指定位置的元素)
linkedList.set(1, "李四");
//返回此列表中的元素数
linkedList.size();
//查看所有信息
System.out.println(linkedList);
//获取元素--获取此列表中指定位置的元素
linkedList.get(1);
//获取元素--此列表中的第一个元素
linkedList.getFirst();
//获取元素--此列表中的最后一个元素
linkedList.getLast();
}
}
3、Vector(增删改查)
import org.junit.Test;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Vector;
public class vector {
/**
* Vector的
* 增删改查操作
* */
public void Vector_Test(){
Vector v = new Vector<>();
//新增--新增一个数据
v.add("你好");
//在新增--添加一个数据(在此列表中的指定位置插入指定的元素)
v.add(1,"张三");
//删除--删除一个数据
v.remove("你好");
//删除--删除一个数据(删除该列表中指定位置的元素)
v.remove(1);
//删除--删除列表中所有数据
v.clear();
//增加空间容量(需要增加此量的容量,以确保它可以至少保存最小容量参数指定的组件数。)
v.ensureCapacity(5); //增加5
//比较--与指定对象进行比较,来判断是否相等
v.equals("张三");
//获取元素--获取此列表中指定位置的元素
v.get(1);
//返回哈希值
v.hashCode();
//获取元素--获取此量中指定元素第一次出现的索引
v.indexOf("你好");
//插入--在指定的位置插入指定对象作为该量中的第一个index
v.insertElementAt("你好", 1);
//自动排序(以正确的顺序返回该列表中的元素迭代器)
v.iterator();
}
}
Vector
类实现了可扩展的对象数组。 像数组一样,它包含可以使用整数索引访问的组件。 但是, Vector
的大小可以根据需要增长或缩小,以适应在创建Vector
之后添加和删除项目。有关详细信息,请参阅博客 jdk_api_1.8-JAVA中文版API手册(免费版)-CSDN博客 中提供的APL工具,查看各个实体文档和子类文档进行深入了解!
总结不易,希望uu们不要吝啬亲爱的👍哟(^U^)ノ~YO!!如有问题,欢迎评论区批评指正😁