java List集合(ArrayList,LinkedList,Vector)

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的* 增删改查操作* */@Testpublic 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的* 增删改查操作* */@Testpublic 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("你好");//插入--在指定的位置插入指定对象作为该量中的第一个indexv.insertElementAt("你好", 1);//自动排序(以正确的顺序返回该列表中的元素迭代器)v.iterator();}
}

Vector类实现了可扩展的对象数组。 像数组一样,它包含可以使用整数索引访问的组件。 但是, Vector的大小可以根据需要增长或缩小,以适应在创建Vector之后添加和删除项目。有关详细信息,请参阅博客 jdk_api_1.8-JAVA中文版API手册(免费版)-CSDN博客 中提供的APL工具,查看各个实体文档和子类文档进行深入了解!

总结不易,希望uu们不要吝啬亲爱的👍哟(^U^)ノ~YO!!如有问题,欢迎评论区批评指正😁

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/228198.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于Eclipse+Mysql+Tomcat开发的挖掘机配件营销系统

基于EclipseMysqlTomcat开发的挖掘机配件营销系统 项目介绍&#x1f481;&#x1f3fb; 大家都有目共睹&#xff0c;现在的科学技术发展很迅速。而如今&#xff0c;计算机应用已经完全融入到人们的生产和生活当中&#xff0c;特别是企业&#xff0c;现在的企业几乎都是离不开计…

如何解决中小制造业企业信息化难题?

中小企的信息化&#xff0c;难&#xff01; 一、中小制造业企业信息化困难的原因主要有以下几点&#xff1a; 资金限制&#xff1a;中小制造业企业相对于大型企业来说资金有限&#xff0c;无法投入大量资金进行信息化建设。技术水平不足&#xff1a;中小制造业企业缺乏专业的…

【力扣】189. 轮转数组

【力扣】189. 轮转数组 文章目录 【力扣】189. 轮转数组1. 题目介绍2. 解法2.1 方法一&#xff1a;不太正规&#xff0c;但是简单2.2 方法二&#xff1a;使用额外的数组2.3 方法三&#xff1a;环状替换2.4 方法四&#xff1a;数组翻转 3. Danger参考 1. 题目介绍 给定一个整数…

leetcode刷题详解十

188. 买卖股票的最佳时机 IV&#xff08;最多买卖k次&#xff09; 注意事项 这道题和最多买卖两次是一模一样的思路就是把2换成k了但是还是有几个地方需要注意的 给的整数数组可能为0k其实没有很大&#xff0c;可以想一下&#xff0c;最多为n/2(n是数组的长度) int maxProfit…

win10 tensorrt源码编译onnx

直接利用官方源码&#xff0c;如下图&#xff0c;trtexec源码在TensorRT安装目录下&#xff0c;双击trtexec.sln文件&#xff0c;使用vs2019打开源码工程。 如下图&#xff0c;以yolov8为例子&#xff0c;编译成功项目之后&#xff0c;设置命令行参数&#xff1a; --onnxd:/yo…

IDEA不支持Java8了怎么办?

IDEA不支持Java8了怎么办&#xff1f; 01 异常发生场景 当我准备创建一个springboot项目时&#xff0c;发现Java8没了 02 问题的产生及其原因 查阅了官方文档之后&#xff0c;确认了是Spring Boot 不再支持 Java 8&#xff0c;不是我的问题&#xff0c;这一天终于还是来了 0…

pytest自动化测试执行环境切换的两种解决方案

一、痛点分析 在实际企业的项目中&#xff0c;自动化测试的代码往往需要在不同的环境中进行切换&#xff0c;比如多套测试环境、预上线环境、UAT环境、线上环境等等&#xff0c;并且在DevOps理念中&#xff0c;往往自动化都会与Jenkins进行CI/CD&#xff0c;不论是定时执行策略…

拆解按摩器:有意思的按键与LED控制电路,学习借鉴一下!

拆解 外观和配色个人感觉还行,比较青春 拉开拉链&#xff0c;拆开外面的布面&#xff0c;里面还有一层纱面 按键部分使用魔术贴固定 拆开纱面后&#xff0c;看到里面的结构&#xff0c;整体是一个海绵 可以看到如下&#xff0c;电池&#xff0c;按键板&#xff0c;充电线的三条…

鸿蒙(HarmonyOS)应用开发——应用程序入口UIAbility

概述 UIAbility是一种包含用户界面的应用组件&#xff0c;主要用于和用户进行交互 UIAbility是系统调度的单元&#xff0c;为应用提供窗口在其中绘制界面 应用程序的几种交互界面形式 点击桌面图标进入应用 一个应用拉起另一个应用 最近任务列表切回应用 每一个UI Abili…

Rabbitmq发送邮件并消费邮件

&#x1f4d1;前言 本文主要是【Rabbitmq】——Rabbitmq发送邮件并消费邮件的文章&#xff0c;如果有什么需要改进的地方还请大佬指出⛺️ &#x1f3ac;作者简介&#xff1a;大家好&#xff0c;我是听风与他&#x1f947; ☁️博客首页&#xff1a;CSDN主页听风与他 &#x1…

java三大集合类--List

List Set Map 一、List 几个小问题&#xff1a; 1、接口可以被继承吗&#xff1f;&#xff08;可以&#xff09; 2、接口可以被多个类实现吗&#xff1f;&#xff08;可以&#xff09; 3、以下两种写法有什么区别&#xff1f; //List list1new List();是错误的因为List()…

js逆向-某赞滑块

声明 本文仅供学习参考&#xff0c;如有侵权可私信本人删除&#xff0c;请勿用于其他途径&#xff0c;违者后果自负&#xff01; 如果觉得文章对你有所帮助&#xff0c;可以给博主点击关注和收藏哦&#xff01; 前言 目标网站&#xff1a;aHR0cHM6Ly9hY2NvdW50LnlvdXphbi5j…