首页 > 其他分享 >ArravList,LinkedList,Vector的相同点与区别

ArravList,LinkedList,Vector的相同点与区别

时间:2023-12-02 09:33:23浏览次数:37  
标签:LinkedList 迭代 实现 ArrayList ArravList Vector 线程

ArravList,LinkedList,Vector的特性

  • ArrayList:动态数组,使用的时候,只需要操作即可,内部已经实现扩容机制。

    • 线程不安全
    • 有顺序,会按照添加进去的顺序排好
    • 基于数组实现,随机访问速度快,插入和删除较慢一点
    • 可以插入null元素,且可以重复
  • Vector和前面说的ArrayList很是类似,这里说的也是1.8版本,它是一个队列,但是本质上底层也是数组实现的。同样继承AbstractList,实现了List,RandomAcess,Cloneable, java.io.Serializable接口。具有以下特点:

    • 提供随机访问的功能:实现RandomAcess接口,这个接口主要是为List提供快速访问的功能,也就是通过元素的索引,可以快速访问到。
    • 可克隆:实现了Cloneable接口
    • 是一个支持新增,删除,修改,查询,遍历等功能。
    • 可序列化和反序列化
    • 容量不够,可以触发自动扩容
    • **最大的特点是:线程安全的*,相当于线程安全的ArrayList
  • LinkedList:链表结构,继承了AbstractSequentialList,实现了List,Queue,Cloneable,Serializable,既可以当成列表使用,也可以当成队列,堆栈使用。主要特点有:

    • 线程不安全,不同步,如果需要同步需要使用List list = Collections.synchronizedList(new LinkedList());
    • 实现List接口,可以对它进行队列操作
    • 实现Queue接口,可以当成堆栈或者双向队列使用
    • 实现Cloneable接口,可以被克隆,浅拷贝
    • 实现Serializable,可以被序列化和反序列化

ArravList,LinkedList,Vector的相同点与区别

​ Java提供了许多集合类来处理和操作数据,其中ArrayList、LinkedList和Vector是常见的几种。这些集合类具有相似的功能,但在实现和性能方面存在一些区别。本文将详细介绍ArrayList、LinkedList和Vector的相同点和区别,并提供相应的源代码示例。

相同点:

  1. 都实现了List接口:ArrayList、LinkedList和Vector都实现了Java的List接口,因此它们都支持有序的元素集合,并且允许元素重复。
  2. 支持动态添加和删除元素:这三个集合类都提供了添加、删除和修改元素的方法,可以根据需要动态地调整集合的大小。
  3. 支持迭代:所有这些集合类都可以使用迭代器(Iterator)来遍历集合中的元素。
  4. 可以存储任意类型的对象:ArrayList、LinkedList和Vector都可以存储任意类型的对象,包括基本类型的包装类。

区别:

  1. 底层实现方式:ArrayList和Vector底层都使用数组实现,而LinkedList使用双向链表实现。这导致它们在插入和删除元素时的性能表现有所不同。ArrayList和Vector在随机访问时性能较好,而LinkedList在插入和删除元素时性能更佳。
  2. 线程安全性:Vector是线程安全的,它的所有方法都经过同步处理,可以在多线程环境下使用。而ArrayList和LinkedList则不是线程安全的,如果在多线程环境下使用它们,需要自行处理线程同步问题。
  3. 扩容方式:当集合需要扩容时,ArrayList默认增加当前容量的一半,而Vector默认增加当前容量的一倍。这也是为什么在大量数据操作时,Vector的性能可能会比ArrayList略差的原因之一。

迭代器

LinkedList源码中一共定义了三个迭代器:

  • Itr:实现了Iterator接口,是AbstractList.Itr的优化版本。
  • ListItr:继承了Itr,实现了ListIterator,是AbstractList.ListItr优化版本。
  • ArrayListSpliterator:继承于Spliterator,Java 8 新增的迭代器,基于索引,二分的,懒加载器。

VectorArrayList基本差不多,都是定义了三个迭代器:

  • Itr:实现接口Iterator,有简单的功能:判断是否有下一个元素,获取下一个元素,删除,遍历剩下的元素
  • ListItr:继承Itr,实现ListIterator,在Itr的基础上有了更加丰富的功能。
  • VectorSpliterator:可以分割的迭代器,主要是为了分割以适应并行处理。和ArrayList里面的ArrayListSpliterator类似。

LinkedList里面定义了三种迭代器,都是以内部类的方式实现,分别是:

  • ListItr:列表的经典迭代器
  • DescendingIterator:倒序迭代器
  • LLSpliterator:可分割迭代器

标签:LinkedList,迭代,实现,ArrayList,ArravList,Vector,线程
From: https://www.cnblogs.com/yhm050305/p/17871262.html

相关文章

  • 集合框架(二)LinkedList的常见使用
    一、介绍链表(Linkedlist)是一种常见的基础数据结构,是一种线性表,但是并不会按线性的顺序存储数据,而是在每一个节点里存到下一个节点的地址。链表可分为单向链表和双向链表。以下情况使用LinkedList:你需要通过循环迭代来访问列表中的某些元素。需要频繁的在列表开头、中间、末尾......
  • Java 中ArrayList,LinkedList,Vector集合的相同点与区别是什么?
    ArrayList,LinkedList和Vector都继承自List接口。ArrayList和Vector的底层是动态数组,LinkedList的底层是双向链表.  ArrayList,LinkedList,Vector的区别我们先来了解ArravListArrayList:的数据结构是数组特点:查询快,增删慢,效率高,但是线程不安全Vector:数据结构是数组特点:查询快,......
  • 集合LinkedList的常见使用
    什么是LinkedList集合LinkedList集合是Java编程语言中的一种双向链表数据结构,它实现了List接口和Deque接口。与ArrayList类似,LinkedList也是一种动态数组,可以根据需要动态地增加或减少元素的大小。然而,LinkedList与ArrayList在内部实现和性能方面有所不同Lin......
  • 集合框架(二)LinkedList的常见使用
    LinkedList:非同步集合LinkedList不是同步集合,如果需要在多线程环境下访问该集合,需要手动实现线程同步。双向链表实现LinkedList内部使用双向链表来表示集合元素,每个节点都存储了元素、前驱节点和后继节点信息。添加/删除元素的效率较高由于是链表实现,LinkedList的添加/删除......
  • ArrayList、LinkedList、Vector三种Java集合框架的同义
    ArrayList、LinkedList、Vector是Java集合框架中的三种数据结构,它们的相同点和不同点如下:相同点:都实现了List接口,可以存储有序的元素序列,可以允许重复元素的存在;都支持随机访问(根据元素的索引访问元素),并且访问效率较高;都支持添加、删除、修改等操作,可以动态调整集合中的元素......
  • LinkedList的常见使用方法
    1、addbooleanadd(Ee):在链表后添加一个元素,如果成功,返回true,否则返回false;voidaddFirst(Ee):在链表头部插入一个元素;addLast(Ee):在链表尾部添加一个元素;voidadd(intindex,Eelement):在指定位置插入一个元素。 2、removeEremove():移除链表中第一个元素;booleanremove(Ob......
  • Java集合框架之:LinkedList的常见方法使用
    ✨前言✨本篇文章主要介绍JavaLinkedList的使用方法教程及示例代码......
  • Vector
    在Java中,Vector是一个非常重要的数据结构,它是一个动态数组,可以在运行时动态地增加或减少元素。Vector的基本操作   添加元素:使用add()方法可以将元素添加到Vector的末尾。此外,add(index,element)方法可以在指定的索引处添加元素。Vector<Integer>vector=newVector<Inte......
  • Java集合ArrayList,LinkedList,Vector的相同点与区别是什么?
    ✨前言✨本篇作为,java集合中ArrayList,LinkedList,Vector常用集合的分析概括,已便大家认识这三种集合的区别,和特点......
  • java List集合(ArrayList,LinkedList,Vector)
    Hii,mJinXiang⭐前言⭐本篇文章主要介绍java List集合的三种实现类ArrayList,LinkedList,Vector以及部分理论知识......