Java 入门第四篇 集合

Java 入门第四篇 集合

一,什么是集合

在这里插入图片描述

在Java中,集合(Collection)是一种用于存储和操作一组对象的容器类。它提供了一系列的方法和功能,用于方便地管理和操作对象的集合。集合框架是Java中非常重要和常用的一部分,它包含了多个接口和类,如List、Set、Map等。

集合的作用有以下几个方面:

  1. 动态存储:集合可以动态地存储和管理对象,不需要事先指定容量大小。与数组相比,集合可以根据需要自动扩展和缩小。

  2. 灵活的操作:集合提供了丰富的方法和功能,可以方便地进行添加、删除、查找、排序等操作。它们封装了复杂的数据结构和算法,使得操作更加简单和高效。

  3. 泛型支持:集合框架支持泛型,可以指定集合中存储的对象类型,提高类型安全性和代码的可读性。

  4. 提供了多种集合类型:集合框架提供了多种不同类型的集合,如List、Set、Map等,每种类型都有不同的特点和适用场景。这样可以根据具体需求选择合适的集合类型。

尽管数组在某些方面与集合相似,但集合具有更多的优势和功能,使得它们成为更常用的数据结构。相对于数组,集合具有动态存储和灵活操作的特点,可以方便地处理不确定数量的对象,而不需要手动管理容量。此外,集合还提供了更多的功能和算法,使得开发人员能够更高效地处理和操作数据。

总而言之,集合是一种用于存储和操作一组对象的容器,它提供了动态存储、灵活操作、泛型支持以及多种集合类型等优势。通过使用集合,我们可以更方便地处理和操作数据,提高代码的可读性和可维护性。

在Java中,集合框架提供了多个接口和类,用于表示和操作不同类型的集合。以下是Java中常用的集合接口和类的列表:

  1. Collection接口:

    • List接口:有序、可重复的集合,例如ArrayList、LinkedList、Vector等。
    • Set接口:无序、不可重复的集合,例如HashSet、TreeSet、LinkedHashSet等。
  2. Map接口:

    • HashMap类:无序的键值对集合,根据键进行快速查找,键不可重复。
    • TreeMap类:有序的键值对集合,根据键的自然顺序进行排序。
    • LinkedHashMap类:有序的键值对集合,维护插入顺序或访问顺序。
    • Hashtable类:与HashMap类类似,但是线程安全(已废弃,推荐使用ConcurrentHashMap)。
    • ConcurrentHashMap类:线程安全的HashMap实现。
  3. Queue接口:

    • LinkedList类:双向队列,可以用作队列、栈或双端队列。
    • PriorityQueue类:优先级队列,根据元素的优先级进行排序。

除了上述常用的集合接口和类,Java还提供了一些其他的集合类,如BitSet、Stack等。此外,Java 8引入了Stream API,它提供了一种新的方式来处理集合和数据流。

需要注意的是,集合接口和类位于java.util包下。它们都是Java标准库的一部分,可以直接使用,无需额外导入。

总结起来,Java中有多个集合接口和类,用于表示和操作不同类型的集合。这些集合提供了丰富的方法和功能,可以满足不同的需求。根据具体的场景和需求,选择合适的集合类型可以提高代码的效率和可读性。

二,ArrayList

在Java中,ArrayList是一个动态数组,它实现了List接口。ArrayList可以根据需要自动调整大小,并且可以存储任意类型的对象。下面是Java ArrayList的语法介绍和讲解:

  1. 导入ArrayList类:
    在使用ArrayList之前,需要在Java代码中导入java.util.ArrayList类,可以通过以下语句实现导入:

    import java.util.ArrayList;
    
  2. 创建ArrayList对象:
    要创建一个ArrayList对象,可以使用以下语法:

    ArrayList<数据类型> arrayList = new ArrayList<>();
    

    在尖括号中指定ArrayList中存储的数据类型。例如,要创建一个存储整数的ArrayList,可以使用以下语句:

    ArrayList<Integer> arrayList = new ArrayList<>();
    
  3. 添加元素:
    使用add()方法向ArrayList中添加元素。例如,要向ArrayList中添加一个整数,可以使用以下语句:

    arrayList.add(10);
    

    可以连续多次调用add()方法来添加多个元素。

  4. 访问元素:
    可以使用索引来访问ArrayList中的元素。索引从0开始,使用get()方法获取指定索引位置的元素。例如,要获取ArrayList中第一个元素,可以使用以下语句:

    int element = arrayList.get(0);
    
  5. 修改元素:
    可以使用索引和set()方法修改ArrayList中的元素。例如,要将ArrayList中的第一个元素修改为新的值,可以使用以下语句:

    arrayList.set(0, newValue);
    
  6. 删除元素:
    可以使用索引或对象来删除ArrayList中的元素。使用remove()方法并指定要删除的索引或对象。例如,要删除ArrayList中的第一个元素,可以使用以下语句:

    arrayList.remove(0);
    

    如果要删除特定对象,可以使用对象作为参数:

    arrayList.remove(object);
    
  7. 获取ArrayList的大小:
    使用size()方法可以获取ArrayList中元素的数量。例如,要获取ArrayList的大小,可以使用以下语句:

    int size = arrayList.size();
    
  8. 遍历ArrayList:
    可以使用for循环或迭代器来遍历ArrayList中的元素。以下是使用for循环遍历ArrayList的示例:

    for (int i = 0; i < arrayList.size(); i++) {
        int element = arrayList.get(i);
        // 处理元素
    }
    

    可以根据需要在循环中执行相应的操作。

这些是Java中ArrayList的基本语法介绍和讲解。ArrayList提供了一组方便的方法来操作和管理动态数组,使得在处理集合数据时更加便捷。

三,HashMap

在Java中,HashMap是一种常用的集合类,它实现了Map接口,用于存储键值对。下面是Java HashMap的语法代码教程和讲解:

  1. 导入HashMap类:
    在使用HashMap之前,需要在Java代码中导入java.util.HashMap类,可以通过以下语句实现导入:

    import java.util.HashMap;
    
  2. 创建HashMap对象:
    要创建一个HashMap对象,可以使用以下语法:

    HashMap<键的数据类型, 值的数据类型> hashMap = new HashMap<>();
    

    在尖括号中指定键和值的数据类型。例如,要创建一个存储字符串作为键和整数作为值的HashMap,可以使用以下语句:

    HashMap<String, Integer> hashMap = new HashMap<>();
    
  3. 添加键值对:
    使用put()方法向HashMap中添加键值对。例如,要向HashMap中添加一个键为"key",值为10的键值对,可以使用以下语句:

    hashMap.put("key", 10);
    

    可以连续多次调用put()方法来添加多个键值对。

  4. 获取值:
    可以使用键来获取HashMap中的值。使用get()方法并指定键来获取对应的值。例如,要获取键为"key"的值,可以使用以下语句:

    int value = hashMap.get("key");
    

    如果键不存在,get()方法将返回null。

  5. 修改值:
    可以使用键和put()方法修改HashMap中的值。例如,要将键为"key"的值修改为新的值,可以使用以下语句:

    hashMap.put("key", newValue);
    
  6. 删除键值对:
    可以使用键来删除HashMap中的键值对。使用remove()方法并指定要删除的键。例如,要删除键为"key"的键值对,可以使用以下语句:

    hashMap.remove("key");
    
  7. 判断键是否存在:
    可以使用containsKey()方法来判断HashMap中是否包含指定的键。例如,要检查是否存在键为"key"的键值对,可以使用以下语句:

    boolean contains = hashMap.containsKey("key");
    
  8. 获取HashMap的大小:
    使用size()方法可以获取HashMap中键值对的数量。例如,要获取HashMap的大小,可以使用以下语句:

    int size = hashMap.size();
    
  9. 遍历HashMap:
    可以使用for-each循环或迭代器来遍历HashMap中的键值对。以下是使用for-each循环遍历HashMap的示例:

    for (Map.Entry<键的数据类型, 值的数据类型> entry : hashMap.entrySet()) {
        键的数据类型 key = entry.getKey();
        值的数据类型 value = entry.getValue();
        // 处理键值对
    }
    

    在循环中,可以通过entry.getKey()获取键,通过entry.getValue()获取值。

这些是Java中HashMap的基本语法代码教程和讲解。HashMap提供了一种方便的方式来存储和管理键值对数据,它具有快速的查找和插入性能,适用于许多常见的编程任务。

四,Set

在Java中,Set是一种集合接口,它表示一组不重复的元素。Set接口没有定义特定的顺序,不允许重复元素。Java提供了多个Set的实现类,如HashSet、LinkedHashSet和TreeSet。下面是Java Set的语法代码教程和讲解:

  1. 导入Set类:
    在使用Set之前,需要在Java代码中导入java.util.Set类,可以通过以下语句实现导入:

    import java.util.Set;
    
  2. 创建Set对象:
    Set是一个接口,不能直接实例化,需要使用Set的实现类来创建对象。例如,要创建一个HashSet对象,可以使用以下语法:

    Set<数据类型> set = new HashSet<>();
    

    在尖括号中指定Set中存储的数据类型。可以根据需要选择其他Set的实现类,如LinkedHashSet或TreeSet。

  3. 添加元素:
    使用add()方法向Set中添加元素。例如,要向Set中添加一个元素,可以使用以下语句:

    set.add(element);
    

    Set会自动确保元素的唯一性,如果添加重复的元素,Set将忽略重复的元素。

  4. 删除元素:
    使用remove()方法从Set中删除元素。例如,要删除Set中的一个元素,可以使用以下语句:

    set.remove(element);
    
  5. 判断元素是否存在:
    使用contains()方法可以判断Set中是否包含指定的元素。例如,要检查Set中是否存在一个元素,可以使用以下语句:

    boolean contains = set.contains(element);
    
  6. 获取Set的大小:
    使用size()方法可以获取Set中元素的数量。例如,要获取Set的大小,可以使用以下语句:

    int size = set.size();
    
  7. 遍历Set:
    可以使用for-each循环或迭代器来遍历Set中的元素。以下是使用for-each循环遍历Set的示例:

    for (数据类型 element : set) {
        // 处理元素
    }
    

    在循环中,可以通过element变量访问Set中的每个元素。

Set接口提供了一种方便的方式来存储和管理不重复的元素集合。根据具体的需求,可以选择不同的Set实现类,并使用Set的方法来操作和处理集合中的元素。

五,Queue

在Java中,Queue是一种接口,表示一组元素的队列。队列是一种先进先出(FIFO)的数据结构,元素按照插入的顺序排列,新元素插入到队列的尾部,而从队列中获取元素时从头部开始获取。Java提供了多个Queue的实现类,如LinkedList和PriorityQueue。下面是Java Queue的语法代码教程和讲解:

  1. 导入Queue类:
    在使用Queue之前,需要在Java代码中导入java.util.Queue类,可以通过以下语句实现导入:

    import java.util.Queue;
    
  2. 创建Queue对象:
    Queue是一个接口,不能直接实例化,需要使用Queue的实现类来创建对象。例如,要创建一个LinkedList对象作为Queue,可以使用以下语法:

    Queue<数据类型> queue = new LinkedList<>();
    

    在尖括号中指定Queue中存储的数据类型。可以根据需要选择其他Queue的实现类,如PriorityQueue。

  3. 添加元素:
    使用offer()方法向Queue中添加元素。例如,要向Queue中添加一个元素,可以使用以下语句:

    queue.offer(element);
    
  4. 获取并删除队头元素:
    使用poll()方法从Queue中获取并删除队头元素。例如,要获取并删除队头元素,可以使用以下语句:

    数据类型 element = queue.poll();
    

    如果队列为空,poll()方法将返回null。

  5. 获取但不删除队头元素:
    使用peek()方法从Queue中获取但不删除队头元素。例如,要获取但不删除队头元素,可以使用以下语句:

    数据类型 element = queue.peek();
    

    如果队列为空,peek()方法将返回null。

  6. 判断队列是否为空:
    使用isEmpty()方法可以判断Queue是否为空。例如,要检查Queue是否为空,可以使用以下语句:

    boolean isEmpty = queue.isEmpty();
    
  7. 获取Queue的大小:
    使用size()方法可以获取Queue中元素的数量。例如,要获取Queue的大小,可以使用以下语句:

    int size = queue.size();
    

Queue接口提供了一种方便的方式来实现队列数据结构,可以按照先进先出的顺序处理元素。根据具体的需求,可以选择不同的Queue实现类,并使用Queue的方法来操作和处理队列中的元素。

六,队列

ArrayBlockingQueue是Java中的一个FIFO阻塞队列实现类,它基于数组实现,并具有固定的容量。下面是关于ArrayBlockingQueue的语法和讲解:

  1. 导入相关类:
    在使用ArrayBlockingQueue之前,需要在Java代码中导入相关的类。可以使用以下语句导入所需的类:

    import java.util.concurrent.ArrayBlockingQueue;
    import java.util.concurrent.BlockingQueue;
    
  2. 创建ArrayBlockingQueue对象:
    使用ArrayBlockingQueue类来创建ArrayBlockingQueue对象。例如,要创建一个容量为capacityArrayBlockingQueue对象,可以使用以下语法:

    BlockingQueue<数据类型> queue = new ArrayBlockingQueue<>(capacity);
    

    在尖括号中指定队列中存储的数据类型,括号中指定队列的容量。

  3. 添加元素:
    使用put()方法向ArrayBlockingQueue中添加元素。该方法会在队列已满时阻塞,直到队列有空间可用。例如,要向队列中添加一个元素,可以使用以下语句:

    queue.put(element);
    
  4. 获取并删除队头元素:
    使用take()方法从ArrayBlockingQueue中获取并删除队头元素。该方法会在队列为空时阻塞,直到队列中有新的元素可用。例如,要获取并删除队头元素,可以使用以下语句:

    数据类型 element = queue.take();
    
  5. 获取但不删除队头元素:
    使用peek()方法从ArrayBlockingQueue中获取但不删除队头元素。例如,要获取但不删除队头元素,可以使用以下语句:

    数据类型 element = queue.peek();
    

    如果队列为空,peek()方法将返回null

  6. 判断队列是否为空:
    使用isEmpty()方法可以判断ArrayBlockingQueue是否为空。例如,要检查队列是否为空,可以使用以下语句:

    boolean isEmpty = queue.isEmpty();
    
  7. 获取队列的大小:
    使用size()方法可以获取ArrayBlockingQueue中元素的数量。例如,要获取队列的大小,可以使用以下语句:

    int size = queue.size();
    

ArrayBlockingQueue是一个线程安全的队列实现,适用于多线程环境。它提供了阻塞等待的特性,可以在队列为空或已满时阻塞线程,以实现线程间的同步和协调。通过使用ArrayBlockingQueue,可以方便地实现生产者-消费者模式等多线程场景。

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

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

相关文章

番茄病虫害检测系统:融合感受野注意力卷积(RFAConv)改进YOLOv8

1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 研究背景与意义 番茄是全球重要的蔬菜作物之一&#xff0c;具有广泛的经济和营养价值。然而&#xff0c;番茄病虫害的严重威胁导致了产量和质量的损失。因此&#xff0c;开发一种…

hive聚合函数之排序

1 全局排序&#xff08;Order By&#xff09; Order By&#xff1a;全局排序&#xff0c;只有一个Reduce。 (1&#xff09;.使用Order By子句排序 asc&#xff08;ascend&#xff09;&#xff1a;升序&#xff08;默认&#xff09; desc&#xff08;descend&#xff09;&#…

C#- 代理模式(静态)

与装饰器模式类似&#xff0c;只继承接口&#xff1b; 示例代码&#xff1a; interface IStudent {public void GetInfo(); } class Student : IStudent {public void GetInfo(){Console.WriteLine("上小学中。。。");} } class ProxyStudent : IStudent {private …

纸质表格扫描转Excel的利器,让您省钱省劲

将纸质表格扫描到电脑Excel上是一种快捷而高效的数字化处理方法&#xff0c;使得数据可以方便地进行编辑、分析和共享。本文将介绍几种常用的方法来完成这项任务。 第一种方法是使用扫描仪。现代扫描仪具备较高的分辨率和颜色还原能力&#xff0c;可以将纸质表格转化为高质量的…

操作系统原理-作业三-存储器

某页式虚拟存储管理系统中&#xff0c;页面大小为 2KB &#xff0c;某一进程分配到的内存块数为 3 &#xff0c;并按下列地址顺序引用内存单元&#xff1a; 2531 、 6632 、 4140 、 3584 、 2892 、 5743 、 1700 、 2148 、 6940、 4345 、 3209 、 0732 、 6202 、 4541 。…

SAP ABAP 使用cl_md_bp_maintain=>maintain更新BP税号CN0的数据,更新结果都会变成CN5类型问题处理

SAP ABAP 使用cl_md_bp_maintain>maintain更新BP税号CN0的数据&#xff0c;更新结果都会变成CN5类型&#xff0c;CN1类型一切正常。 1、BP税号 2、跟踪方法中代码 查看底层逻辑&#xff0c;发现CN0都被强制替换成CN5了&#xff0c;BP GUI界面还能正常使用CN0. 查询NOTES&a…

机器学习:从概念到应用

机器学习&#xff1a;从概念到应用 一、引言 随着科技的飞速发展&#xff0c;人工智能已经渗透到我们生活的方方面面。作为人工智能领域的一个重要分支&#xff0c;机器学习正在改变我们的世界。它通过让计算机从数据中学习&#xff0c;实现自我优化和改进&#xff0c;为各行…

JS轮询任务查询订单退款状态

出现问题&#xff1a; 因为订单的支付不是普通的微信支付&#xff0c;是第三方支付&#xff0c;而且由于该三方支付自己内部设置的一些情况&#xff0c;导致退款的时候&#xff0c;发起了退款申请&#xff0c;但是会在15~20秒左右&#xff0c;才会返回结果&#xff0c;不像微信…

ISCTF2023 Reverse方向 WP

文章目录 ReversecrackmeEasyRebabyReeasy_z3FloweyRSAeasy_flower_teamfx_rez3_revengeWHERE Reverse crackme 、 加了UPX壳&#xff0c;可以看到EP Section处UPX标识被修改了 用WinHex修改 之后UPX脱壳 得到flag。 EasyRe 逆向一下&#xff0c;先逆序&#xff0c;再做一些…

台阶仪在大型基板应用有哪些

探针式轮廓仪&#xff08;台阶仪&#xff09;是一种用于测量物体表面轮廓和形状的仪器。在大型基板应用中&#xff0c;它可能被用于检测和分析半导体器件、平板显示屏、光伏电池板等大尺寸基板上的微小结构和形状。这样的测量对于确保生产质量、提高制造效率和优化工艺非常重要…

cfa一级考生复习经验分享系列(三)

从总成绩可以看出&#xff0c;位于90%水平之上&#xff0c;且置信区间全体均高于90%线。 从各科目成绩可以看出&#xff0c;所有科目均位于90%线上或高于90%线&#xff0c;其中&#xff0c;另类与衍生、公司金额、经济学、权益投资、固定收益、财报分析表现较好&#xff0c;目测…

张驰课堂:在线六西格玛认证,成就个人职业发展

随着数字化学习平台的兴起&#xff0c;六西格玛的学习方式更加灵活。以下是线上学习平台与传统面授培训的对比&#xff1a; 线上学习平台&#xff1a; 灵活性&#xff1a;学员可以根据自己的时间安排自学&#xff0c;不受地点限制。 成本效益&#xff1a;通常在线课程费用较低…

MySQL中的时间函数整理汇总

1.获取当前时间 -- 获取当前时间 SELECT NOW(); -- 获取当前日期 SELECT CURDATE(); -- 获取当前时分秒 SELECT CURTIME(); 2.获取对应日期对应的年/月/日/月份名/星期数 -- 返回对应日期对应的年/月/日/月份名/星期数 select year(now())as 年,month(now())as 月,day(now())…

迅速理解什么是通信前置机

通信前置机设在两个通信对象之间&#xff0c;是实质性的物理服务器&#xff0c;适应不同通信协议或数据格式之间的相互转换。 前置机的作用&#xff1a; 隔离——隔离客户端与服务端&#xff0c;保障后端安全减负——处理非核心业务&#xff0c;分担后端服务器压力&#xff0…

CBTC2024 • 零碳未来!CBTC上海储能技术展览会

国际氢能投融资与发展联盟、 湖南省电池产业协会 、沪粤储能产业联盟主办的一场备受瞩目的盛会——2024年CBTC上海国际储能技术展。储能技术是当今全球能源领域的核心热点之一&#xff0c;也是实现能源转型和可持续发展的重要途径。CBTC上海国际储能技术展是全球规模最大、最具…

临界资源访问一个有趣现象

先看一个例子&#xff1a;我们创建10个线程&#xff0c;每一个线程对同一个地址上的值都进行加一100000次&#xff0c;那最后结果是不是1000000呢&#xff1f; #include <stdio.h> #include <pthread.h> #include <unistd.h>#define THREAD_COUNT 10void …

阿里云Centos8安装Dockers详细过程

一、卸载旧版本 较旧的 Docker 版本称为 docker 或 docker-engine 。如果已安装这些程序&#xff0c;请卸载它们以及相关的依赖项。 yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \do…

OpenHarmony应用编译 - 如何在源码中编译复杂应用

功能简介 在OpenHarmony系统中预安装应用的hap包会随系统编译打包到镜像中&#xff0c;目前有两种编译预安装应用hap包的方式&#xff0c;一种为随系统编译时&#xff0c;编译应用源码生成hap包的方式&#xff0c;另一种是将已生成的hap包放入系统源码中&#xff0c;再进行打包…

three.js聚光源SpotLight例子

效果&#xff1a; 说明&#xff1a;这里创建了SphereGeometry 球缓冲几何体&#xff0c;使用的材质是兰伯特网格材质MeshLambertMaterial&#xff0c;并对球缓冲几何体使用了纹理贴图效果&#xff0c;添加了聚光源&#xff0c;全部代码如下&#xff1a; <template><d…

Redis队列原理解析:让你的应用程序运行更加稳定!

一、消息队列简介 消息队列&#xff08;Message Queue&#xff09;&#xff0c;字面意思就是存放消息的队列。最简单的消息队列模型包括 3 个角色&#xff1a; 消息队列&#xff1a;存储和管理消息&#xff0c;也被称为消息代理&#xff08;Message Broker&#xff09;生产者…