Java List集合
6 List集合
- List系列集合:添加的元素是有序,可重复,有索引
- ArrayList: 添加的元素是有序,可重复,有索引
- LinkedList: 添加的元素是有序,可重复,有索引
- Vector :是线程安全的,速度慢,开发中很少使用
6.1 List集合概述和特点
List集合概述
1、有序集合(也称为序列),用户可以精确控制列表中每个元索的插入位置。用户可以通过整数索引访问元素,并获取列表中的元素
2、与Set集合不同,List集合允许重复的元素
List集合特点
1、有序: 存储和取出的元素顺序一致
2、可重复: 存储的元素可以重复
package ceshi;import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;public class ListDemo {public static void main(String[] args) {//创建集合对象List<String> list = new ArrayList<>();//添加元素list.add("java");list.add("天下");list.add("无敌");list.add("java");System.out.println(list); //[java, 天下, 无敌, java]//迭代器遍历Iterator<String> it = list.iterator();while(it.hasNext()) {String s = it.next();System.out.println(s);/*java天下无敌java*/}}
}
6.2 List集合的特有方法
方法名 | 说明 |
---|---|
public void add(int index,E element) | 该集合中的指定位置上插入元素 |
public E remove(int index) | 删除列表中指定位置的元素,返回被删除的元素 |
public E set(int index,E element) | 修改指定索引的元素,返回被修改的元素 |
public E get(int index) | 返回集合中指定位置的元素 |
package ceshi;import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;public class ListDemo {public static void main(String[] args) {//创建集合对象List<String> list = new ArrayList<>();//添加元素list.add("java");list.add("天下");list.add("无敌");list.add("java");System.out.println(list); //[java, 天下, 无敌, java]//1、public void add(int index,E element) 该集合中的指定位置上插入元素list.add(1,"javase");System.out.println(list); //[java, javase, 天下, 无敌, java]//2、public E remove(int index) 删除列表中指定位置的元素,返回被删除的元素System.out.println(list.remove(1)); //javaseSystem.out.println(list); //[java, 天下, 无敌, java]//3、public E set(int index,E element) 修改指定索引的元素,返回被修改的元素System.out.println(list.set(0,"java1")); //javaSystem.out.println(list); //[java1, 天下, 无敌, java]//4、public E get(int index) 返回集合中指定位置的元素System.out.println(list.get(2)); //无敌//for循环遍历for(int i=0;i< list.size();i++) {//5,public E get(int index) 返回集合中指定位置的元素String s = list.get(i);System.out.println(s);/*java1天下无敌java*/}}
}
-
案例
-
测试类
package ceshi;import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;public class ListDemo {public static void main(String[] args) {//2、创建集合对象List<Student> list = new ArrayList<Student>();//3、创建学生对象Student s1 = new Student("y1",10);Student s2 = new Student("y2",20);Student s3 = new Student("y3",30);//4、学生对象添加到集合list.add(s1);list.add(s2);list.add(s3);//5、遍历集合:迭代器方法Iterator<Student> it = list.iterator();while(it.hasNext()) {Student s = it.next();System.out.println(s.getName()+","+s.getAge());/*y1,10y2,20y3,30*/}//5、遍历集合:for循环for(int i=0;i<list.size();i++) {Student ss = list.get(i);System.out.println(ss.getName()+","+ss.getAge());/*y1,10y2,20y3,30*/}}
}
6.3 ListIterator迭代器
- Lstlterator:列表迭代器
- 通过List集合的
listterator()
方法得到,所以说它是List集合特有的迭代器 - 用于允许程序员沿任一方向遍历列表的列表迭代器,在迭代期间修改列表,并获取列表中迭代器的当前位置
- 通过List集合的
- 常用方法
方法名 | 说明 |
---|---|
list.listIterator() | 得到 listIterator 迭代器 |
E next() | 返回迭代中的下一个元素 |
boolean hasNext() | 如果迭代具有更多元素,则返回true |
E previous() [ˈpriːviəs] | 返回列表中的上一个元素 |
boolean hasPrevious() | 如果此列表迭代器在相反方向遍历列表时具有更多元索,则返回true |
void add(E e) | 将指定的元索插入列表 |
package ceshi;import java.util.ArrayList;
import java.util.List;
import java.util.ListIterator;public class ListIteratorDemo {public static void main(String[] args) {List<String> list = new ArrayList<>();list.add("java");list.add("python");list.add("scala");//通过list集合的listIterator() 方法得到迭代器/*ListIterator<String> lit = list.listIterator();while(lit.hasNext()) {String s = lit.next();System.out.println(s);*//*javapythonscala*//*}System.out.println("---------");//逆向遍历*//*E previous0 返回列表中的上一个元素boolean hasPrevious() 如果此列表迭代器在相反方向遍历列表时具有更多元索,则返回true*//*while(lit.hasPrevious()) {String s = lit.previous();System.out.println(s);*//*scalapythonjava*//*}*///获取列表迭代器ListIterator<String> lit = list.listIterator();while(lit.hasNext()) {String s = lit.next();if(s.equals("java")) {lit.add("world");}}System.out.println(list); //[java, world, python, scala]}
}
6.4 foreach(增强for循环)
增强for:简化数组和Collection集合的遍历
- 实现Iterable接口的类允许其对象成为增强型 for语句的目标
- 它是JDK5之后出现的,其内部原理是一个Iterator迭代器
- 格式
for(元素类型 变量名: 数组名或collection集合){ }
//范例
int[] arr = {1,2,3,4,5};
for(int i : arr) {System.out.println(i);
}
- 范例:
package ceshi;import java.util.ArrayList;
import java.util.List;public class ForDemo {public static void main(String[] args) {//int类型数组int[] arr = {1,2,3,4,5};for(int i : arr) {System.out.println(i);/*12345*/}//String类型数组String[] strArray = {"java","python","scala"};for(String s : strArray) {System.out.println(s);/*javapythonscala*/}//集合List<String> list = new ArrayList<>();list.add("y1");list.add("y2");list.add("y3");for(String lt:list) {System.out.println(lt);/*y1y2y3*/}//判断:内部原理是一个Iterator迭代器for(String s:list) {if(s.equals("y1")) {list.add("y4"); //ConcurrentModificationException:并发修改异常}}}
}
6.5 案例:List集合存储学生对象用三种方式遍历
- 测试类
package ceshi;import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;public class ListDemo {public static void main(String[] args) {List<Student> list = new ArrayList<>();Student s1 = new Student("y1",10);Student s2 = new Student("y2",20);Student s3 = new Student("y3",30);list.add(s1);list.add(s2);list.add(s3);//迭代器方式Iterator<Student> it = list.iterator();while(it.hasNext()) {Student s = it.next();System.out.println(s.getName()+","+s.getAge());}System.out.println("----------");//for带索引方式for(int i =0;i<list.size();i++) {Student s = list.get(i);System.out.println(s.getName()+","+s.getAge());}System.out.println("----------");//增强forfor(Student s: list) {System.out.println(s.getName()+","+s.getAge());}}
}
6.6 List集合子类特点
ArrayList
:底层数据结构数组实现,查询快,增删慢LinkedList
:底层数据结构链表实现,查询慢,增删快- 范例:分别用ArrayList和LinkedList存储字符串并遍历
package ceshi;import java.util.ArrayList;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;public class ListDemo {public static void main(String[] args) {//1、创建ArrayList集合对象ArrayList<String> arraylist = new ArrayList<>();arraylist.add("java");arraylist.add("python");arraylist.add("scala");//增强forfor(String s: arraylist) {System.out.println(s);}System.out.println("-------");//普通for循环for(int i=0;i< arraylist.size();i++) {String s = arraylist.get(i);System.out.println(s);}System.out.println("-------");//迭代器的方式Iterator<String> it = arraylist.iterator();while(it.hasNext()) {String s = it.next();System.out.println(s);}System.out.println("-------");//2、创建LinkedList集合对象LinkedList<String> linkedList = new LinkedList<>();linkedList.add("a");linkedList.add("b");linkedList.add("c");//增强forfor(String s:linkedList) {System.out.println(s);}System.out.println("-------");//普通forfor(int i=0;i< linkedList.size();i++) {String s = linkedList.get(i);System.out.println(s);}System.out.println("-------");//迭代器Iterator<String> it1 = linkedList.iterator();while(it1.hasNext()) {String s = it1.next();System.out.println(s);}}
}
6.7 LinkedList集合特有方法
方法名 | 说明 |
---|---|
public void addFirst(E,e) | 在该列表开头插入指定的元素 |
public void addLast(E,e) | 将指定的元索追加到此列表的末尾 |
public E getFirst() | 返回此列表中的第一个元索 |
public E getLast() | 返回此列表中的最后一个元素 |
public E removeFirst | 从此列表中删除并返回第一个元素 |
public E removeLast | 从此列表中删除并返回最后一个元素 |
package ceshi;import java.util.LinkedList;public class LinkedListDemo {public static void main(String[] args) {//创建集合对象LinkedList<String> linkedList = new LinkedList<>();linkedList.add("java");linkedList.add("python");linkedList.add("scala");System.out.println(linkedList); //[java, python, scala]//1、public void addFirst(E,e) 在该列表开头插入指定的元素linkedList.addFirst("1");System.out.println(linkedList); //[1, java, python, scala]//2、public void addLast(E,e) 将指定的元索追加到此列表的末尾linkedList.addLast("5");System.out.println(linkedList); //[1, java, python, scala, 5]//3、public E getFirst() 返回此列表中的第一个元索System.out.println(linkedList.getFirst()); //1//4、public E getLast() 返回此列表中的最后一个元素System.out.println(linkedList.getLast()); //5//5、public E removeFirst 从此列表中删除并返回第一个元素System.out.println(linkedList.removeFirst()); //1System.out.println(linkedList);//[java, python, scala, 5]//6、public E removeLast 从此列表中删除并返回最后一个元素System.out.println(linkedList.removeLast()); //5System.out.println(linkedList); //[java, python, scala]}
}
相关文章:
Java List集合
6 List集合 List系列集合:添加的元素是有序,可重复,有索引 ArrayList: 添加的元素是有序,可重复,有索引LinkedList: 添加的元素是有序,可重复,有索引Vector :是线程安全的ÿ…...
linux服务器挂载硬盘/磁盘
1. 查看机器所挂硬盘个数及分区情况:fdisk -l可以看出来目前/dev/vda 目前有300G可用.内部有两个分区(/dev/vda1,/dev/vda2)。2. 格式化磁盘格式化磁盘命令为【mkfs.磁盘类型格式 目录路径组成】查看磁盘文件格式:df -T格式化磁盘…...
Java 抽象类
文章目录1、抽象方法和抽象类2、抽象类的作用当编写一个类时,常常会为该类定义一些方法,用于描述该类的行为方式,这些方法都有具体的方法体。但在某些情况下,某个基类只是知道其子类应该包含那些方法,但不知道子类是如…...
OpenPPL PPQ量化(5):执行引擎 源码剖析
目录 PPQ Graph Executor(PPQ 执行引擎) PPQ Backend Functions(PPQ 算子库) PPQ Executor(PPQ 执行引擎) Quantize Delegate (量化代理函数) Usage (用法示例) Hook (执行钩子函数) 前面四篇博客其实就讲了下面两行代码: ppq_ir load_onnx_graph(onnx_impor…...
【脚本开发】运维人员必备技能图谱
脚本(Script)语言是一种动态的、解释性的语言,依据一定的格式编写的可执行文件,又称作宏或批处理文件。脚本语言具有小巧便捷、快速开发的特点;常见的脚本语言有Windows批处理脚本bat、Linux脚本语言shell以及python、…...
N字形变换-力扣6-java
一、题目描述将一个给定字符串 s 根据给定的行数 numRows ,以从上往下、从左到右进行 Z 字形排列。比如输入字符串为 "PAYPALISHIRING" 行数为 3 时,排列如下:P A H NA P L S I I GY I R之后,你的输出需要从左往右逐行读…...
概论_第5章_中心极限定理1__定理2(棣莫弗-拉普拉斯中心极限定理)
在概率论中, 把有关论证随机变量和的极限分布为正态分布的一类定理称为中心极限定理称为中心极限定理称为中心极限定理。 本文介绍独立同分布序列的中心极限定理。 一 独立同分布序列的中心极限定理 定理1 设X1,X2,...Xn,...X_1, X_2, ...X_n,...X1,X2,...Xn…...
详细解读503服务不可用的错误以及如何解决503服务不可用
文章目录1. 问题引言2. 什么是503服务不可用错误3 尝试解决问题3.1 重新加载页面3.2 检查该站点是否为其他人关闭3.3 重新启动设备3.3 联系网站4. 其他解决问的方法1. 问题引言 你以前遇到过错误503吗? 例如,您可能会收到消息,如503服务不可…...
【前端vue2面试题】2023前端最新版vue模块,高频17问(上)
🥳博 主:初映CY的前说(前端领域) 🌞个人信条:想要变成得到,中间还有做到! 🤘本文核心:博主收集的关于vue2面试题(上) 目录 vue2面试题 1、$route 和 $router的区别 2、一个…...
数据库(三):多版本并发控制MVCC,行锁的衍生版本,记录锁,间隙锁, Next-Key锁(邻键锁)
文章目录前言一、MVCC以及MVCC的缺点1.1 MVCC可以为数据库解决什么问题1.2 MVCC的基本思想1.3 版本号1.4 Undo日志1.5 ReadView1.6 快照读和当前读1.6.1 快照读1.6.2 当前读二、记录锁三、间隙锁四、邻键锁总结前言 一、MVCC以及MVCC的缺点 MVCC,即多版本并发控制…...
c# 自定义隐式转换与运算符重载
用户定义的显式和隐式转换运算符 参考代码 用户定义的显式和隐式转换运算符 - 提供对不同类型的转换 | Microsoft Learn 代码例程 using System;public readonly struct Digit {private readonly byte digit;public Digit(byte digit){if (digit > 9){throw new Argumen…...
【MyBatis】| MyBatis的逆向⼯程
目录 一:MyBatis的逆向⼯程 1. 逆向⼯程配置与⽣成 2. 测试生成的逆向⼯程 一:MyBatis的逆向⼯程 (1)所谓的逆向⼯程是:根据数据库表逆向⽣成Java的pojo类,SqlMapper.xml⽂件,以及Mapper接⼝…...
Python|每日一练|哈希表|罗马数字|图算法|圆周率|单选记录:给定数列和|罗马数字转整数|计算圆周率
1、要求编写函数fn(a,n) 求aaaaaa⋯aa⋯aa(n个a)之和,fn须返回的是数列和(算法初阶) 要求编写函数fn(a,n) 求aaaaaa⋯aa⋯aa(n个a)之和,fn须返回的是数列和。 从控制台输入正整数a和n的值(两…...
分布式之分布式事务V2
写在前面 本文一起来看下分布式环境下的事务问题,即我们经常听到的分布式事务问题。想要解决分布式事务问题,需要使用到分布式事务相关的协议,主要有2PC即两阶段提交协议,TCC(try-confirm-cancel)…...
算法笔记(二)—— 认识N(logN)的排序算法
递归行为的时间复杂度估算 整个递归过程是一棵多叉树,递归过程相当于利用栈做了一次后序遍历。 对于master公式,T(N)表明母问题的规模为N,T(N/b)表明每次子问题的规模,a为调用次数,加号后面表明,除去调用之…...
最长湍流子数组——滚动窗口,双指针,暴力求解
978. 最长湍流子数组难度中等216收藏分享切换为英文接收动态反馈给定一个整数数组 arr ,返回 arr 的 最大湍流子数组的长度 。如果比较符号在子数组中的每个相邻元素对之间翻转,则该子数组是 湍流子数组 。更正式地来说,当 arr 的子数组 A[i]…...
45.在ROS中实现global planner(1)
前文move_base介绍(4)简单介绍move_base的全局路径规划配置,接下来我们自己实现一个全局的路径规划 1. move_base规划配置 ROS1的move_base可以配置选取不同的global planner和local planner, 默认move_base.cpp#L70中可以看到是…...
Java中导入、导出Excel——HSSFWorkbook 使用
一、介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统、银行系统)。或者是:我们已经习惯用Excel打印。这样在我们实际的开发中,很多时候需要…...
c#数据结构-列表
列表 数组可以管理大量数组,但缺点是无法更变容量。 创建小了不够用,创建大了浪费空间。 无法预测需要多少大小的时候,可能范围越大,就会浪费越多的空间。 所以,你可能会想要一种可以扩容的东西,代替数组…...
Sa-Token实现分布式登录鉴权(Redis集成 前后端分离)
文章目录1. Sa-Token 介绍2. 登录认证2.1 登录与注销2.2 会话查询2.3 Token 查询3. 权限认证3.1 获取当前账号权限码集合3.2 权限校验3.3 角色校验4. 前后台分离(无Cookie模式)5. Sa-Token 集成 Redis6. SpringBoot 集成 Sa-Token6.1 创建项目6.2 添加依…...
leaflet显示高程
很多地图软件都能随鼠标移动动态显示高程。这里介绍一种方法,我所得出的。1 下载高程数据一般有12.5m数据下载,可惜精度根本不够,比如mapbox的免费在线的,或者91卫图提供百度网盘打包下载的,没法用,差距太大…...
电子学会2022年12月青少年软件编程(图形化)等级考试试卷(三级)答案解析
目录 一、单选题(共25题,共50分) 二、判断题(共10题,共20分) 三、编程题(共3题,共30分) 青少年软件编程(图形化)等级考试试卷(三级) 一、单选题(共25题,共50分) 1. 默认小猫角色…...
ubuntu 驱动更新后导致无法进入界面
**问题描述: **安装新ubuntu系统后未禁止驱动更新导致无法进入登录界面。 解决办法: 首先在进入BIOS中,修改设置以进行命令行操作,然后卸载已有的系统驱动,最后安装新的驱动即可。 开机按F11进入启动菜单栏…...
解决访问GitHub时出现的“您的连接不是私密连接”的问题!
Content问题描述解决办法问题描述 访问github出现您的连接不是私密连接问题,无法正常访问,如下图所示: 解决办法 修改hosts文件。hosts文件位于:C:\Windows\System32\drivers\etc\hosts 首先在https://www.ipaddress.com/查找两…...
初识数据仓库
一、什么是数据仓库数据库 --> OLTP:(on-line transaction processing)翻译为联机事务处理记录某类业务事件的发生,如购买行为,银行交易行为,当行为产生后,系统会记录是谁在何时何地做了何事…...
FilenameUtils工具类部分源码自研
FilenameUtils工具类部分源码自研getExtension(orgFileName)源码如下逐行分析getExtension(orgFileName)源码如下 public class FilenameUtils {public static int indexOfExtension(String fileName) throws IllegalArgumentException {if (fileName null) {return -1;} els…...
【前端领域】3D旋转超美相册(HTML+CSS)
世界上总有一半人不理解另一半人的快乐。 ——《爱玛》 目录 一、前言 二、本期作品介绍 3D旋转相册 三、效果展示 四、详细介绍 五、编码实现 index.html style.css img 六、获取源码 公众号获取源码 获取源码?私信?关注?点赞&…...
Java——聊聊JUC中的原子变量类
文章目录: 1.什么是原子变量类? 2.AtomicInteger(基本类型原子变量类) 3.AtomicIntegerArray(数组类型原子变量类) 4.AtomicMarkableReference(引用类型原子变量类) 5.AtomicInteger…...
elasticsearch索引与搜索初步
ES支持cURL交互,使用http请求完成索引和搜索操作,最基本的格式如下:创建索引我们可以使用PUT方法创建索引,通过指定“索引”、“类型”、“文档ID”锁定文档,通过参数指定文档的数据。红色部分的路由分别指定了“索引”…...
【Python】多线程与多进程学习笔记
本文是一篇学习笔记,学习内容主要来源于莫凡python的文档:https://mofanpy.com/tutorials/python-basic/threading/thread 多线程 线程基本结构 开启子线程的简单方式如下: import threadingdef thread_job():print(This is a thread of %…...
深圳网站建设公司报价单/虎门今日头条新闻
API 现在无处不在。因此,现代开发人员需要一种高效的查询语言 GraphQL 如果您不熟悉 API(应用程序接口),它是 2 个应用程序相互交互的一种方式。例如,如果您单击 Facebook 上的“上传您的照片”按钮,API 将允许您将您的照片上传到 Facebook。有成千上万的 API 可供程序员…...
十堰网站建设公司0719web/seo基础教程视频
iptables/netfilter详解一、前言1.防火墙(Firewall)是隔离工具;工作于主机或网络的边缘,对经由的报文根据预先定义的规则(识别条件)进行检测, 对于能够被规则匹配到的报文实行某预定义的…...
真做视频网站/杭州网站搜索排名
一. Oracle 11g 默认审计说明 之前整理的一篇有关审计的说明: Oracle Audit 审计 说明 http://www.cndba.cn/Dave/article/1469 在Maclean 的blog上看到了2篇介绍Oracle 11g 默认审计的文章,原文链接如下: 11g默认审计选项 http://www.oracl…...
wordpress博客页修改/百度营销推广靠谱吗
一、废话 听说很多地方都降温了,希望大家注意身体,别冻着了! 二、正文 在Android的网络通讯中,通常会使用Socket进行设备间数的数据通讯,使用Http来对网络数据进行请求。 1、Socket(套接字) 不管…...
免费微信小程序制作/百度seo流量
链表05--复杂链表的复制-jz25题目概述解析&参考答案注意事项说明题目概述 算法说明 输入一个复杂链表(每个节点中有节点值,以及两个指针,一个指向下一个节点,另一个特殊指针random指向一个随机节点),请…...
如何建设网站主页和其他相关页面/seo关键词排名优化要多少钱
《HTML5介绍ppt课件.ppt》由会员分享,可在线阅读,更多相关《HTML5介绍ppt课件.ppt(20页珍藏版)》请在人人文库网上搜索。1、Welcome to HTML 5,什么是HTML5,HTML5的特点,HTML5的新特性,简介趋势,优势 var cxtc.getContext(2d); var grdcxt.createLinearG…...