集合Collection-List-ArrayList学习

一、集合

集合是数据容器。相较于数组集合具有以下几个特点:

  • 数组一旦创建,长度不可改变。集合的长度会自动扩容。
  • 集合具有很多数组没有的功能函数API
  • 数组元素的存储特点单一,不同的集合有不同的存储特点。

在这里插入图片描述

1. Collection顶层接口

Collection表示一组对象,这些对象也称为collection的元素。有的是有序的List, 有的是无序的Set。

Collection c = new ArrayList();//多态的方式创建一个Collection类

1.1增删改查和其他操作

函数作用
add()添加元素
remove()删除元素
contains()判断是否包含
toArray()转换成数组
clear()清空集合
size()获取集合元素个数
retainAll()求两个集合的交集
removeAll()求两个集合的差集

1.2迭代器遍历

函数作用
iterator()获取当前集合的迭代器对象
hasNext()判断是否有下一个元素
next()取出下一个元素
remove()移除当前元素

    public void test1(){
        Collection c = new ArrayList();

        //添加元素
        c.add("tom");
        c.add("jack");
        c.add("rose");
        c.add("jerry");

        //获取迭代器
        Iterator iterator = c.iterator();
        while(iterator.hasNext()){
            Object obj = iterator.next();
            System.out.println(obj);
        }
    }

1.3 foreach循环

foreach增强for循环是jdk5的新特性,通常用于遍历数组和Collection集合。相较于for循环,无法在遍历过程中得到元素的下标,进而无法直接修改元素,只能读取元素,但语法形式更为简单。
底层是使用迭代器来实现的,只有实现了Iterable接口的类才能使用foreach()来进行遍历。Collection类继承了Iterable接口,所以所有集合类都能够使用foreach和Iterator迭代器来实现所有元素的遍历。

注:实现了Iterator接口的类都可以使用foreach循环遍历。

for(元素类型 变量 :数组或Collection集合对象){
	//循环体
}

//遍历数组
int[] arr = {11, 22, 33};
for(int i : arr){
	System.out.println(i);
}

//遍历集合与上述代码类似,只是将数组名称改为集合名称

1.4 迭代器的快速失败机制

在使用迭代器遍历集合时, 有外部代码在同时修改元素集合,迭代器会迅速抛出ConcurrentModificationException。

例如,通常不允许一个线程在另一个线程迭代Collection时修改它。通常,在这些情况下,迭代的结果是不确定的。如果检测到这种行为,一些Iterator实现(包括JRE提供的所有通用集合实现)可能会选择抛出此异常。这样做的迭代器被称为<快速失败>迭代器,因为它们快速而干净地失败,而不是在未来不确定的时间冒任意的、不确定的行为的风险。

机制:当创建迭代器时,会使用变量modCount记录当前集合的修改次数。每次取出元素前都会检查判断该变量是否修改过,如果修改过,立即抛出异常。该机制并不能完全保证不会有外部代码修改元素。


    public void test1(){
        Collection c = new ArrayList();

        //添加元素
        c.add("tom");
        c.add("jack");
        c.add("rose");//倒数第二个不会抛出异常
        c.add("jerry");

        //获取迭代器
        Iterator iterator = c.iterator();
        while(iterator.hasNext()){//遍历
            Object obj = iterator.next();
            if("jack".equals(obj)){
                //c.remove(obj);//集合的remove方法
                //迭代器自身的remove方法
                iterator.remove();
            }
            //System.out.println(obj);
        }


        System.out.println(c);
    }

2. List子接口

Collection有两个子接口,分别是List和Set。List集合的特点主要是以下几点:

  • 元素是有序的
  • 元素可以重复,Set集合不允许重复
  • 可以通过索引访问元素

2.1 特有方法

List继承了父类Collection的方法,此外特有的方法都是通过下标找到指定位置来访问数据而增加的方法。

 //截取一个子集合
        List subList = list.subList(0,2);
        System.out.println("subList = " + subList);

        //获取元素首次出现的位置
        int java = list.indexOf("java");
        System.out.println(java);

        //删除指定索引位置的元素
        Object remove = list.remove(1);//返回被删除的元素
        System.out.println("remove = " + remove);

        //替换指定位置的元素,返回被替换的元素
        Object java1 = list.set(1, "JAVA");
        System.out.println("java1 = " + java1);

2.2 List集合的遍历

  • 迭代器遍历:可以使用迭代器的remove方法进行删除。
  • 增强for循环:无法修改集合里面的元素
  • 普通for循环:可删除,可修改。
  • ListIterator迭代器
  • 普通for循环:

2.3 ListIterator迭代器

Iterator接口的子接口,增加了(添加元素、修改元素、判断是否有上一个元素、取出上一个元素) 这几个方法。并且它的构造器可以定义遍历的开始位置。

//从第二个位置开始遍历
ListIterator iterator= new ListIterator(2);

查看是否有上一个元素:该方法是ListIterator特有的方法,使用该方法可以倒着遍历整个List集合。

iterator.hasPrevious();

3. ArrayList类

使用空参构造器创建对象,底层数组容量为0。第一次添加元素时,初始化容量为10。当放入数据大于初始容量时,数组扩容为原容量的1.5倍。增删时如果容量不足,需要动态扩容,效率不高,查询时直接通过数组索引查询,效率高。

特点:

  • 元素有序可重复,可以通过索引访问
  • 底层结构:
    • 数组
    • 增删慢,索引查找速度快

4. Vector类

底层也是数组实现的,线程安全的。ArrayList是线程不安全的。数组容量不足时,容量扩充到原先的2倍。效率低,不推荐使用。

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

用python来爬取某鱼的商品信息(2/2)

目录 上一篇文章 本章内容 设置浏览器为运行结束后不关闭&#xff08;可选&#xff09; 定位到搜索框的xpath地址 执行动作 获取cookie 保存为json文件 修改cookie的sameSite值并且导入cookie 导入cookie&#xff08;出错&#xff09; 导入cookie&#xff08;修改后&…

Jmeter(五) - 从入门到精通 - 创建网络计划实战和创建高级Web测试计划(详解教程)

1.简介 上一篇中已经将其的理论知识介绍了一下&#xff0c;这一篇就带着大家一步一步的把上一篇介绍的理论知识实践一下&#xff0c;然后再说一下如何创建高级web测试计划。 2.网络计划实战 通过上一篇的学习&#xff0c;将其分类为&#xff1a; &#xff08;1&#xff09;不需…

python -- 函数闭包

1. LEGB规则 L: local 是局部作用域 E: Enclosed 是嵌套函数的外层函数作用域 G: Global 全局作用域 B:Build-In 内置作用域 变量的使用权重&#xff1a;局部变量 > 外层作用域变量 > 全局变量 > 内置变量 下面代码执行后&#xff0c;x变量的值分别为多少&#xff1…

KafkaStream:Springboot中集成

1、在kafka-demo中创建配置类 配置kafka参数 package com.heima.kafkademo.config;import lombok.Data; import org.apache.kafka.common.serialization.Serdes; import org.apache.kafka.streams.StreamsConfig; import org.springframework.boot.context.properties.Configu…

怎么做Tik Tok海外娱乐公会呢?新加坡市场怎么样?

一、为什么选择TikTok直播 1. 海外市场潜力巨大 • 自2016年始&#xff0c;多家直播平台陆续拓展至东南亚、中东、俄罗斯、日韩、欧美、拉美等地区。 • 海外市场作为直播发展新蓝海&#xff0c;2021年直播行业整申请cmxyci体规模达百亿美元&#xff0c;并维持高速增长。 &a…

【数据结构系列】链表

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kuan 的首页,持续学…

异常(下)Java常见异常,异常的使用原则

文章目录 前言一、Java常见异常 1.常见异常2.实例展示二、异常的使用原则总结 前言 该文介绍了Java的一些常见异常&#xff0c;并给出对应的例子进行解释。介绍异常的使用原则&#xff0c;即创建&#xff0c;抛出异常的编程规范。 一、Java常见异常 前要&#xff1a;Java API中…

sklearn机器学习库(一)sklearn中的决策树

sklearn机器学习库(一)sklearn中的决策树 sklearn中决策树的类都在”tree“这个模块之下。 tree.DecisionTreeClassifier分类树tree.DecisionTreeRegressor回归树tree.export_graphviz将生成的决策树导出为DOT格式&#xff0c;画图专用tree.export_text以文字形式输出树tree.…

Jmeter(六) - 从入门到精通 - 建立数据库测试计划(详解教程)

1.简介 在实际工作中&#xff0c;我们经常会听到数据库的性能和稳定性等等&#xff0c;这些有时候也需要测试工程师去评估和测试&#xff0c;因此这篇文章主要介绍了jmeter连接和创建数据库测试计划的过程,在文中通过示例和代码非常详细地介绍给大家&#xff0c;希望对各位小伙…

基于YOLOv8+PyQt5开发的行人过马路危险行为检测告警系统(附数据集和源码下载)

系列文章目录 文章目录 系列文章目录前言欢迎来到我的博客&#xff01;我很高兴能与大家分享关于基于YOLOv8的行人过马路危险行为检测告警系统的内容。 一、系统特点1. 采用最新最优秀的目标检测算法YOLOv82. 系统分别基于PyQt5开发了两种GUI图形界面&#xff0c;供大家学习使用…

consul安装启动流程

普通软件包安装 首先cd /opt &#xff0c;将安装包放到该目录下 下载consul安装包 进入consul官网找到自己开发平台对应的安装包下载 https://www.consul.io/downloads.html 或使用命令 wget https://releases.hashicorp.com/consul/1.6.2/consul_1.6.2_linux_amd64.zip (如果…

解决lldb调试时可能出现的personality set failed: Function not implemented

最近在尝试使用Visual Studio 2022远程连接Linux进行C/C的开发&#xff0c;由于CentOS风波不断&#xff0c;所以现在的开发基本上都是使用ubuntu了&#xff0c;但是目前VS2022有一些BUG&#xff0c;就是远程调试时&#xff0c;如果目标系统是ubuntu则会出现启动调试器很慢的问题…

js设置css变量控制页面一行展示指定个数的元素

前置知识&#xff1a; CSS变量之var()函数的应用——动态修改样式 & root的使用 flex相关知识 场景&#xff1a; 动态设置给父元素内子元素设置每行排列几个 通过 document.body.style.setProperty(--itemNum, 5)设置样式变量&#xff0c;然后通过给父元素设置display: f…

PyQt5的信号与槽函数

目录 一、介绍 二、一个信号连接一个槽 三、一个信号连接多个槽 四、多个信号连接一个槽 五、自定义信号 1、创建自定义信号 2、让自定义信号携带值 一、介绍 在下图中 &#xff08;1&#xff09;widget就是PyQt中的控件对象。其实就是组件&#xff08;2&#xff09;…

uniapp 用 hbuilderx下载 uview

uView2.0重磅发布&#xff0c;利剑出鞘&#xff0c;一统江湖 - DCloud 插件市场 1.uniapp官网下载资源 2按下载 3.官网安装文档 要按 这个红色圈错了 然后看他的配置步骤 第四easycom 就可以 不用配了

Linux MQTT智能家居(温度,湿度,环境监测,摄像头等界面布局设置)

文章目录 前言一、温度湿度曲线布局二、环境监测界面布局三、摄像头界面布局总结 前言 本篇文章来完成另外三个界面的布局设置。 这里会使用到 feiyangqingyun的一些控件库。 一、温度湿度曲线布局 TempHumtiy.h: #ifndef TEMPHUMTIY_H #define TEMPHUMTIY_H#include <…

Java-运算符和控制语句(上)(基于c语言的补充)

算术运算符 关于求余 不管分子&#xff0c;分母是正还是负&#xff0c;对于分母&#xff0c;直接取正&#xff1b;对于分子若有负号&#xff0c;则先提取出来&#xff1b;剩下两个正的分子分母运算&#xff1b;最后&#xff0c;若刚才的分子有负号&#xff0c;对最后的结果添加…

[C语言] 指针

1. 指针是什么 2. 指针和指针类型 3. 野指针 4. 指针运算 5. 指针和数组 6. 二级指针 7. 指针数组 目录 1. 指针是什么&#xff1f; 2. 指针和指针类型 2.1 指针-整数 2.2 指针的解引用 3. 野指针 3.1 野指针成因 3.2 如何规避野指针 4. 指针运算 4.1 指针…

第三课-界面介绍SD-Stable Diffusion 教程

前言 我们已经安装好了SD&#xff0c;这篇文章不介绍难以理解的原理&#xff0c;说使用。以后再介绍原理。 我的想法是&#xff0c;先学会画&#xff0c;然后明白原理&#xff0c;再去提高技术。 我失败过&#xff0c;知道三天打鱼两天晒网的痛苦&#xff0c;和很多人一样试了…

Windows - UWP - 网络不好的情况下安装(微软商店)MicrosoftStore的应用

Windows - UWP - 网络不好的情况下安装&#xff08;微软商店&#xff09;MicrosoftStore的应用 前言 UWP虽然几乎被微软抛弃了&#xff0c;但不得不否认UWP应用给用户带来的体验。沙箱的运行方式加上微软的审核&#xff0c;用户使用起来非常放心&#xff0c;并且完美契合Wind…