Java中创建List接口、ArrayList类和LinkedList类的常用方法(一)

List接口

要了解List接口,就不得不说起Java的集合框架。
Java集合框架图(来自菜鸟教程)
(该图来自菜鸟教程)

Collection接口和Map接口

Java 集合框架主要包括两种类型的容器,集合Collection和图Map。

  • Collection接口代表了单列集合,它包含了一组Object元素,每个元素都有一个值。
    (这里有个“泛型擦除”的概念,在此不提及有兴趣可自行了解)
  • Map接口代表了双列集合,它包含了一组键值对,每个键值对包含两个值,一个是键,一个是对应的值。

List

Collection 接口又有 3 种子类型,List、Set 和 Queue。

  • List 接口存储一组不唯一,有序(插入顺序)的对象。
    1. 不唯一:允许存储重复的元素。
    2. 有序:可以精准控制元素添加的位置,因此可以根据索引访问元素。
    3. <实现类有ArrayList,LinkedList,Vector> 。
  • Set 接口存储一组唯一,无序的对象。
    1. 唯一:元素不允许重复。
    2. 无序:没有定义顺序,元素的存储顺序可能与添加顺序不同。
  • Queue接口:一个先进先出(FIFO)的集合,通常用于模拟队列数据结构。

静态数组

概念

  1. 是一种线性数据结构。
  2. 相同类型的元素存储在连续的内存空间中。

初始化

java中两种创建静态数组的形式如下,

 int[] array = new int[5];  // { 0, 0, 0, 0, 0 } int[] iarray = { 1, 2, 3, 5, 4 }; 
    • 第一行代码创建了一个名叫array的数组,长度大小为5,并且数组的长度大小不能改变
    • 注释的意思是,java会自动给数组内的元素赋值为默认值,即int型的默认值0。
  1. 第二行代码创建了一个名叫iarray的数组,长度大小为5,并且长度大小也无法改变,且编写者主动赋值为一到五的数字。

ArrayList类

ArrayList类相关图(来自于菜鸟教程)

概念和性质

  • ArrayList 继承了 AbstractList类 ,并实现了 List 接口
    (AbstractList是List接口的抽象实现类,它继承自AbstractCollection类,并实现了List接口中的方法。)
  • ArrayList基于动态数组实现,内部使用一个数组来存储元素,当数组容量不足时,会进行扩容操作,通常创建一个新的更大的数组,并将原数组的元素复制到新数组中。
  • 插入删除性能
    1. 倘若在末尾进行插入和删除操作的性能较好
    2. 但若在中间或开头进行插入删除操作时,需要移动后续元素,性能较差。
  • 随机访问性能支持通过索引进行快速的随机访问,效率较快。

使用

初始化

ArrayList初始化的基本格式如下,

import java.util.ArrayList; // 引入 ArrayList 类ArrayList<ElemType> objectName =new ArrayList<>();  // 初始化

ElemType是数组中对象(元素)的引用类型数据,objectName是数组名字。
(注意注意下文中的Element是ElemType引用类型的基本类型。)


(因为实际ArrayList中的元素是对象,所以需要引用类型)
(String可以像使用基本类型一样,但实际是引用类型)

基本类型引用类型
booleanBoolean
byteByte
shortShort
intInteger
longLong
floatFloat
doubleDouble
charCharacter

例如,

import java.util.ArrayList; ArrayList<Integer> arrayList =new ArrayList<>();  

避免繁琐后边的代码例子中引入 ArrayList 类就不写了。

add() 添加元素

ArrayList<ElemType> objectName =new ArrayList<>();
objectName.add(ElemType e);
objectName.add(InterPre i, ElemType e);

可以看到,add()函数有两种添加方法,

  • 直接在数组的末尾添加元素e
  • 索引 i 前面添加元素e
    如,
ArrayList<Integer> arrayList = new ArrayList<>();
arrayList.add(1);
arrayList.add(2);
arrayList.add(3);
arrayList.add(0,6);
for(int i : arrayList) System.out.print(i + " ");//这里的for循环迭代是依次得到数组中的元素,后边会讲
//输出:6 1 2 3 

remove() 删除元素

ArrayList<ElemType> objectName =new ArrayList<>();
objectName.remove(index i);

作用:删除索引为 i 上的元素,如

ArrayList<Integer> arrayList = new ArrayList<>();
arrayList.add(1);
arrayList.add(2);
arrayList.add(3);
arrayList.remove(2);
for(int i : arrayList) System.out.print(i + " ");
//输出:1 2

get() 访问元素

ArrayList<ElemType> objectName =new ArrayList<>();
objectName.get(index i);

作用:返回索引为i处上的元素,如

ArrayList<Integer> arrayList = new ArrayList<>();
arrayList.add(1);
arrayList.add(2);
arrayList.add(3);
System.out.println(arrayList.get(2));
//输出:3

set() 修改元素

ArrayList<ElemType> objectName =new ArrayList<>();
objectName.set(index i, ElemType e);

作用:将索引为 i 上的元素修改为 e,如

ArrayList<Integer> arrayList = new ArrayList<>();
arrayList.add(1);
arrayList.add(2);
arrayList.add(3);
arrayList.set(1,6);
for(int i : arrayList) System.out.print(i + " ");
//输出:1 6 3

size() 元素数量

int ArrayLength = arrayList.size();

作用:**返回数组的长度,**赋值给ArrayLenth。如,

ArrayList<Integer> arrayList = new ArrayList<>();
arrayList.add(1);
arrayList.add(2);
arrayList.add(3);
System.out.println(arrayList.size());
//输出:3

其余函数

下面就不给出示例代码和输出结果啦,太多了,但是会给出基本格式和用法。

ArrayList<ElemType> arraylist =new ArrayList<>();
  • void arraylist.clear() :删除arraylist 中的所有元素

  • boolean arraylist.contains(ElemType e) :判断元素e是否在arraylist中,如果在返回true,否则返回false

  • int arraylist.indexOf(ElemType e) :返回元素e在arraylist中的索引
    • 若重复出现,返回最先的索引值;
    • 若不存在,返回-1。

  • boolean arraylist.isEmpty() :判断arraylist是否为空,为空返回true,否则返回false

  • void arraylist.removeAll() :作用与arraylist.clear()相同,但是arraylist.clear()时间更快。

  • void arraylist.sort(): 将数组排序,使用方法这里略过后面详细说明。

  • Elem[] arraylist.toArray(Elem[] num) :将arraylist转化为数组赋给num,数组的元素类型为同引用类型的基本类型。

  • String arraylist.toString():将arraylist转化为String类型返回。

迭代数组列表

第一种,通过普通for循环迭代,依次输出arraylist中的元素。

ArrayList<ElemType> arraylist = new ArrayList<>();
/*
......
(赋值操作)
*/
for (int i = 0; i < arraylist.size(); i++) System.out.println(arraylist.get(i));

第二种,通过for-each迭代,依次输出arraylist中的元素,也就是上文给出的方式。

ArrayList<ElemType> arraylist = new ArrayList<>();
/*
......
(赋值操作)
*/
for (Element e : arraylist) System.out.println(e);

注意Element是ElemType引用类型的基本类型。

ArrayList排序

借助Collections 类

import java.util.Collections;  // 引入 Collections 类Collections.sort(arraylist);

注意Collections.sort()是升序排序(从小到大)。

本身的sort() 方法

arraylist.sort(Comparator c)

Comparator c 的意思是排序方式,分别为升序和降序。

  • 升序参数为 Comparator.naturalOrder()
  • 降序参数为 Comparator.reverseOrder()
    注意要使用这两个参数,需要引入Comparator类。
    实例如下,
import java.util.Comparator;arraylist.sort( Comparator.naturalOrder()) ;
//得到数组升序排序的结果(从小到大)
arraylist.sort( Comparator.reverseOrder());
//得到数组降序排序的结果(从大到小)

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

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

相关文章

高通平台开发系列讲解(USB篇)DWC3控制USB速率

文章目录 一、设备树二、相关结构体三、最大速率设置四、当前速率设置沉淀、分享、成长,让自己和他人都能有所收获!😄 📢本文主要介绍高通平台USB DWC3控制USB速率。 一、设备树 目录:msm-4.14/arch/arm64/boot/dts/qcom/sdxprairie-usb.dtsi dwc3@a600000 {compatibl…

机房中,为什么UPS系统这么重要?一篇看懂

在当今数字化和信息化的时代&#xff0c;企业对于电力供应的稳定性和可用性提出了越来越高的要求。机房作为关键的信息技术基础设施之一&#xff0c;其稳定的电源是确保业务连续运行的基石。 在这一背景下&#xff0c;UPS监控系统的作用愈发凸显&#xff0c;成为保障电力稳定、…

当前vscode环境下 多进程多线程运行情况探究

我的代码 其中在“打开图片时”、“进入子进程之前”、“子进程join前”、“进入子进程区域后”&#xff0c;“子进程join后”、“进入子线程区域后”分别打印了进程线程的编号和数量。 # -*- coding: utf-8 -*-# Form implementation generated from reading ui file test2.…

SPI传感器接口设计与优化:基于STM32的实践

SPI&#xff08;串行外设接口&#xff09;是一种常用的串行通信协议&#xff0c;用于在微控制器和外部设备之间进行全双工的高速数据传输。在本文中&#xff0c;我们将探讨如何基于STM32微控制器设计和优化SPI传感器接口&#xff0c;并提供相应的代码示例。 1. SPI传感器接口设…

Github 2024-01-16 Python开源项目日报 Top10

根据Github Trendings的统计&#xff0c;今日(2024-01-16统计)共有10个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Python项目10HTML项目1 精心策划的Python资源列表 创建周期&#xff1a;3490 天开发语言&#xff1a;Python…

Ubuntu20.04安装配置OpenCV-Python库并首次执行读图

一、选择三方提供的预编译包安装&#xff1a; 可以从官网下载 OpenCV 的安装包&#xff0c;编译后使用&#xff1b;也可以直接使用第三方提供的预编译包 安装。显然后者不需要执行编译步骤&#xff0c;更便捷。选择由 PyPI 提供的 OpenCV 安装包&#xff0c;可以在 https://py…

Springboot日志框架logback与log4j2

目录 Springboot日志使用 Logback日志 日志格式 自定义日志格式 日志文件输出 Springboot启用log4j2日志框架 Springboot日志使用 Springboot底层是使用slf4jlogback的方式进行日志记录 Logback日志 trace&#xff1a;级别最低 debug&#xff1a;调试级别的&#xff0c…

获取域控的方法

在域渗透中、作为渗透测试人员&#xff0c;获取域控的权限基本上可以获取整个内网的权限 1.高权限读取本地密码 当域管理员在域成员机器上登录进行工作的时候&#xff0c;会将明文密码保存在本地进行的lsass.exe&#xff0c;可以通过 mimikatz来读取到本地的明文密码。 priv…

【Java 设计模式】结构型之适配器模式

文章目录 1. 定义2. 应用场景3. 代码实现结语 适配器模式&#xff08;Adapter Pattern&#xff09;是一种结构型设计模式&#xff0c;用于将一个类的接口转换成客户端期望的另一个接口。这种模式使得原本由于接口不兼容而不能一起工作的类可以一起工作。在本文中&#xff0c;我…

确保您的计算机符合SOLIDWORKS 2024的最低系统配置要求

在现代工程和设计领域中&#xff0c;SOLIDWORKS 2024 成为了许多专业人士首选的三维建模软件。然而&#xff0c;要确保您充分发挥其潜力&#xff0c;首先需要确保您的计算机符合 SOLIDWORKS 2024 的最低系统要求。本文将为您提供关于系统要求的详细信息&#xff0c;以确保您的工…

多标签节点分类

Multi-Label Node Classification on Graph-Structured Data,TMLR’23 Code 学习笔记 图结构数据的多标签分类 节点表示或嵌入方法 通常会生成查找表&#xff0c;以便将相似的节点嵌入的更近。学习到的表示用作各种下游预测模块的输入特征。 表现突出的方法是基于随机游走(ran…

71.网游逆向分析与插件开发-角色数据的获取-修复角色名与等级显示问题

内容参考于&#xff1a;易道云信息技术研究院VIP课 上一个内容&#xff1a;自动化助手UI显示角色数据-CSDN博客 码云地址&#xff08;ui显示角色数据 分支&#xff09;&#xff1a;https://gitee.com/dye_your_fingers/sro_-ex.git 码云版本号&#xff1a;0049452c079867779…