java进阶—List

news2025/4/5 17:56:36

上节回顾
List 是一个有序的,允许重复的Collection,其下的子类主要有 ArrayList LinkedList,Vector(这个官方不推荐使用)

那么同为list的子类,ArrayList 跟 LinkedList 有什么区别呢?

这里就涉及到了list的底层两种实现方式:

- 一种是数组 (ArayList)

在这里插入图片描述
数组的角标从0 开始 这个我们之前已经知道了,数组的好处查询快,有角标直接定位就好了,但是增删的效率比较慢

当进行删除一个元素操作时,其他元素需要向前或者向后移动

当进行增加一个元素操作时,需要考虑是否需要扩容(集合满了,要创建一个新的更大的数组,把旧数据复制进去)

所以增删比较慢

  • 一种是链表 (LinkedList)
    链表每个元素就不像数组了,它没有自己的角标

链表里面又有单向链表 跟 双向链表

先来看看单向链表

在这里插入图片描述
指针指向元素,每个元素分为两个域,一个是存储元素的 数据域,另一个是指向下一个元素的指针域

再来看看双向链表

在这里插入图片描述
双向链表就分为三个区域了,元素不用说,pre 是指向前一个元素,next: 是指向下一个元素

由于链表没有角标,所以查询起来需要一个一个从头往下查,然而增删相对于数组结构就快的多,删除他只需要继续指向下一个就行了,增加也是,前一个指针指向增加的元素

总结一下:
ArrayList:数组结构,查询快,增删慢

LinkedList:链表结构,查询慢,增删快

那么怎么创建一个list集合呢?

很简单,万事万物皆对象,new一个,(按照具体需求来创建哪一个)

  List<Integer> myList = new ArrayList<>();

  List<Integer> myList = new linkedList<>();

可以看出这边就是多态的运用,向上转型

这边有些刚接触编程小伙伴会有疑惑了,这个 <> 是什么?

其实<> 代表泛型

官方是这样说的:泛型是 1.5中引入的一个新特性,其本质是参数化类型,也就是说所操作的数据类型被指定为一个参数(type parameter)这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。

看不懂,没关系,说人话:

在这边集合中,泛型指的就是你这个集合装什么类型的数据,就好像我们整理东西,这个箱子放衣服,这个箱子放书本,可以理解成贴的标签,下次看一眼这个标签就知道这里面装的是什么

就像这个例子,这个集合里面装的是int (Integer,int 类型的包装类)类型的数据

既然集合容器我们创造出来了,不装点东西那不就是浪费了,所以我们来看看有哪些操作集合的方法

1. 遍历 (读取集合)

先来学习遍历,方便我们后续进行打印输出,除了跟数组遍历方法一样java 基础——数组 ,集合还多了一种遍历方式,自带的迭代器 (基本不用,不建议使用,拿来混个眼熟,知道有这么个东西)

 List<Integer> myList = new ArrayList<>();
        myList.add(1);
        myList.add(3);
        myList.add(5);

        Iterator<Integer> it = myList.iterator();
        while (it.hasNext()) {
            Integer clone = it.next();
            System.out.println(clone);
        }

最主要我们还是使用 以下方式

ist<Integer> myList = new ArrayList<>();
        myList.add(1);
        myList.add(3);
        myList.add(5);

        //通过角标获取
        for (int i = 0; i < myList.size(); i++) {
            System.out.println(myList.get(i));
        }
        //增强for循环
        for (Integer item : myList) {
            System.out.println(item);
        }

        //java8 ,个人这种用的比较多
        myList.forEach(System.out::println);

jdk 1.8 新语法

输出结果:

在这里插入图片描述
1. 添加 (add)

添加是 直接添加数据

List<Integer> myList = new ArrayList<>();
        myList.add(1);
        myList.add(3);
        myList.add(5);
  1. 移除 (remove)

移除是 按照角标来移除

 List<Integer> myList = new ArrayList<>();
        myList.add(1);
        myList.add(3);
        myList.add(5);
        myList.remove(2);
     for (Integer item : myList) {
          System.out.println(item);
     }        

这里就是移除下标为2 的元素,下标为2 就是5 这个数据 ,结果:

在这里插入图片描述
3. 判断集合中是否有该元素(contains)

 List<Integer> myList = new ArrayList<>();
        myList.add(1);
        myList.add(3);
        myList.add(5);

        boolean contains = myList.contains(3);
        System.out.println(contains);

在这里插入图片描述
4. 获取集合的大小(size)

 List<Integer> myList = new ArrayList<>();
        myList.add(1);
        myList.add(3);
        myList.add(5);

        int size = myList.size();
        System.out.println(size);

在这里插入图片描述

5. 判断集合是否为空(isEmpty)

 List<Integer> myList = new ArrayList<>();
        myList.add(1);
        myList.add(3);
        myList.add(5);

        boolean empty = myList.isEmpty();
        System.out.println(empty);

在这里插入图片描述
6. 清空集合(clear)

  List<Integer> myList = new LinkedList<>();
        myList.add(1);
        myList.add(3);
        myList.add(5);
        
        myList.clear();

LinkedList 相对于ArrayList 用的比较少,有些方法自己留个印象

  • 返回此列表的第一个元素
 LinkedList<Integer> myList = new LinkedList<>();
        myList.add(1);
        myList.add(3);
        myList.add(9);

        Integer first = myList.getFirst();
        System.out.println(first);

输出结果:1

  • 返回此列表的最后一个元素

 LinkedList<Integer> myList = new LinkedList<>();
        myList.add(1);
        myList.add(3);
        myList.add(9);

        Integer first = myList.getLast();
        System.out.println(first);

输出结果:9

我们最后来简单看一下Vector, 这个东西在开发中不要用,Vector是线程安全的,这也是一个优点,但是它的效率低,其次Vector满了之后,扩容是一倍,ArrayList 仅仅是一半,面试中要是有问到,回答这些就好,java官方都不建议用这东西

最后我们来一个例子,来增强一下对List的理解

需求:有三个学生,学生对象存放在list中,他们呢都有自己的属性(学号,姓名,考试分数),然后把他们遍历打印出来

分析: 有个类,Student , 有三个私有属性(id,name,score)

public class Student {

    private  Integer id;
    private  String  name;
    private  Double  score;
    
    // 提供公共方法
    public Student(Integer id, String name, Double score) {
        this.id = id;
        this.name = name;
        this.score = score;
    }
    //以字符串形式输出
    @Override
    public String toString() {
        return "Student{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", score=" + score +
                '}';
    }
}

public static void main(String[] args) {
        //创建一个集合,泛型里面声明装的是学生对象
        List<Student> stuList = new ArrayList<>();
        //创建学生对象1
        Student stu1 = new Student(1, "stu1", 100.0);
        //创建学生对象2
        Student stu2 = new Student(2, "stu2", 95.5);
        //创建学生对象3
        Student stu3 = new Student(3, "stu3", 90.0);
        //将学生对象添加到集合中
        stuList.add(stu1);
        stuList.add(stu2);
        stuList.add(stu3);
        //遍历雪上对象,打印到控制台
        for (Student student : stuList) {
            System.out.println(student);
        }


    }

在这里插入图片描述

推荐阅读

java进阶—集合

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《计算机体系结构量化研究方法》第2章-存储器层次结构设计 2.1 引言

一、概述 1、存储器层次结构&#xff1a;层次由速度和容量各不相同的存储器组成。 2、存储器层次结构被分为几个级别——离处理器越近&#xff0c;容量越小速度越快。 3、包含性质&#xff1a;大多数情况下&#xff0c;低层级存储器中的数据是上一级存储器中数据的超集。比如…

基于RSA的数字签名设计与实现

信息安全课程的第二个实验&#xff0c;主要是用java、js&#xff0c;前端页面用的html写的。 页面成果展示&#xff1a; 基本公私钥生成 实验环境为win10系统&#xff0c;使用git命令行工具——git bash生成公私钥。生成私钥&#xff0c;密钥长度为1024bit并从私钥中提取公钥 …

如何在 Spring Boot 项目中开启 “热部署“

目录 1. 添加热部署框架支持 2. 设置当前项目 Settings 和新项目 Settings 开启项目自动编译 3. 开启运行中热部署 4. 使用 Debug 启动项目 (社区版 IDEA) 1. 添加热部署框架支持 在 pom.xml 中添加如下框架引用: <dependency><groupId>org.springframework.b…

vue3中常用的三种组件传值方式

比较大型的项目中经常会涉及到多个组件之间进行传值&#xff0c;所以对之前用过的一些传值方法做个笔记&#xff0c;还有就是对不同的情况下需要使用哪一种传值方法更合适的思维进行一个总结 vue3中常用的三种组件传值方式mitt依赖注入pinia总结mitt 因为vue3去掉了全局事件总…

qt实现的pdf阅读器(二)--XpdfReader在linux下的编译

目录 1.简介 2.需求说明 3.编译 3.3. 下载源码 3.2. 移植安装包和依赖库 3.2.1 准备工作 3.3.2 了解 3.3.3 编译并安装zlib 3.3.4 编译并安装libpng 3.3.5 编译并安装lcms 3.3.6 编译并安装freetype 3.3.7 编译xpdf 3.3.8 查看运行编译好的xpdf 1.简介 Xpdf 是一个免…

我以为自己MySQL够牛逼了,直到看到了Alibaba的面试题

前言 众所周知&#xff0c;简历上“了解&#xff1d;听过名字&#xff1b;熟悉&#xff1d;知道是啥&#xff1b;熟练&#xff1d;用过&#xff1b;精通&#xff1d;做过东西”。 相信大家对于MySQL的索引都不陌生&#xff0c;索引(Index)是帮助MySQL高效获取数据的数据结构。…

SpringBoot Disruptor框架遇到的问题

1.消息重复消费问题 问题描述&#xff1a; 项目中启动了多个消费者,测试中发现同一条消息被多次消费。 解决方案&#xff1a; ①幂等方案处理 ②disrutor提供了不同的处理机制&#xff1a; 自定义消费者实现EventHandler接口,他是属于重复消费&#xff0c; 自定义消费者实现W…

SVN培训笔记(下拉项目、同步修改、添加文件、修改文件、删除文件、改名文件等)

若该文为原创文章&#xff0c;转载请注明原文出处 本文章博客地址&#xff1a;https://hpzwl.blog.csdn.net/article/details/128417196 红胖子(红模仿)的博文大全&#xff1a;开发技术集合&#xff08;包含Qt实用技术、树莓派、三维、OpenCV、OpenGL、ffmpeg、OSG、单片机、软…

【矩阵论】7. 范数理论——非负/正矩阵

7.5 非负/正矩阵 7.5.1 定义 a. 非负/正矩阵定义 一个实矩阵 A(aij)∈RmnA(a_{ij})\in R^{m\times n}A(aij​)∈Rmn 若对每一 iii 和 jjj &#xff0c;aij≥0a_{ij}\ge 0aij​≥0 &#xff0c;则称A是非负矩阵&#xff0c;A≥0A\ge 0A≥0 若对每一 iii 和 jjj &#xff0c;…

简单四则运算语法树可视化

简单四则运算语法树可视化 前几天有一篇博客是关于四则运算和二叉树的&#xff0c;我是把四则运算用二叉树写出来&#xff08;我是用的 JSON 的形式来存储和表达的&#xff09;&#xff0c;并计算最终的结果。最近&#xff0c;也在继续这个方面的东西&#xff0c;不过遇到一些…

uni-app 微信支付-小程序、APP、IOS

小程序 支付 先看官方文档 https://pay.weixin.qq.com/wiki/doc/apiv3/open/pay/chapter2_8_2.shtml 知晓有那些比不可少的流程&#xff0c;之后后端确定返回的参数值&#xff0c;用于前端支付。参数值必须一一对应&#xff0c;不然支付会失败 uni.requestPayment({timeStamp…

mysql5.7主从复制配置

写在最前面&#xff1a;一入编程深似海&#xff0c;从此对象变路人&#xff08;码农没时间谈恋爱&#xff09;。很长一段时间连写个文章的时间都没有了&#xff0c;学完后端、学前端&#xff0c;前端刚入门又要搞容器化&#xff0c;这真是“一重山外一重关&#xff0c;关关难过…

如何在Angular框架中更好地使用字体?一篇文章解答!

作为前端开发人员&#xff0c;在Angular JS中构建项目时&#xff0c;使用自定义字体可能会很棘手。有时候&#xff0c;如果开发者想要把选择的字体添加到项目中&#xff0c;将不得不把它导入到现有的代码中。 PS&#xff1a;Kendo UI致力于新的开发&#xff0c;来满足不断变化…

信息安全产品认证

文章目录一、引言二、《网络关键设备和网络安全专用产品安全认证证书》2.1 背景2.2 产品目录2.3 认证依据标准2.4 认证机构三、《中国国家信息安全产品认证证书》3.1 背景3.2 产品目录3.3 行业跟进四、《IT产品信息安全认证证书》五、CCC认证5.1背景5.2 中国强制性产品认证体系…

多源传感器组合导航 GNSS 视觉SLAM LiDAR INS 开源项目总结

多源传感器组合导航 GNSS 视觉SLAM LiDAR INS 开源项目总结 本文更改自 吴桐wutong 微信公众号文章。 开源代码总览 名称传感器类型组合类型滤波方法备注RTKLIBG-KFGAMP、rtklibexplorerhttps://www.rtklib.com/GPSTKG-KFhttps://github.com/SGL-UT/GPSTkBNCG-KFppp_wizardK…

【多个IP地址用逗号分割开】vue简单实现,textarea文本域输入多个ip地址用逗号分隔开,根据空格分割

前言 这个功能也是很多地方会用到的。 一般使用的地方是比如需要设置白名单或者黑名单 然后页面上会有一个textarea文本域。 在文本域中输入多个ip地址&#xff0c;输入一个回车换一行。 然后点击保存后&#xff0c;把数据通过逗号隔开的格式传给后端 后端再去拿到每一个ip地址…

电脑重装系统win11如何更改默认下载路径

win11如何更改默认下载路径&#xff1f;当大家平日里面&#xff0c;在使用win11系统的时候&#xff0c;如果觉得某一个下载路径的内存空间已经满了的话&#xff0c;那么就必须要及时更改&#xff0c;下面是小编提 供的更改路径的方法。 工具/原料&#xff1a; 系统版本&#x…

ES集群节点角色更换

背景 如何在一个3节点集群中&#xff0c;将Master/Data角色的节点中的数据分散到其他数据节点中&#xff0c;将该节点角色变更为Master 操作步骤 构建集群 集群角色如下 m-01:master/data d-02:data d-03:data 集群配置文件&#xff1a; Master节点elasticsearch.yml配置文件…

关于Maven中引用的jar的version配置为版本区间自动使用最新的版本,maven是如何判断哪个版本更加新?

背景 在Maven中&#xff0c;a工程引入了个jar包&#xff08;b工程&#xff09;&#xff0c;可以使用区间引入的方式&#xff0c;类似于数学区间的写法&#xff0c;如下 <dependency><groupId>org.example</groupId><artifactId>demo-jar</artifac…

使用Anaconda安装TensorFlow详细教程

一、Anaconda安装 可以参考笔者的这篇博客&#xff1a;Anaconda安装详细教程 二、准备工作 1、单击启动Anaconda Prompt创建新虚拟环境 2、在Anaconda Prompt依次执行以下命令conda create -n pytorch python3.6&#xff0c;创建名字为tensorflow的虚拟环境&#xff0c;再通…