Java集合框架(set篇)

本文涉及的产品
函数计算FC,每月15万CU 3个月
应用实时监控服务-应用监控,每月50GB免费额度
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: set集合的特点:set集合的遍历不像集合遍历一样是三种遍历方式了,而是两种:我们为什么要去重,因为如果是添加一个普通的一个元素的话set集合本身是可以去重的,但是如果你是添加一个对象的话他就不能去重了,为什么?因为每个对象他不是同一个地址,所以不能去重,再最后在工作的时候会用别人写的set集合的方法,你不可能叫别人去写,所以是需要自己去写的,所以才需要写set集合的去重。例如,我们可以创建一个HashSet对象用于去重,然后将多个元素添加进去:最终的Set中只包含3个元素,分别是"apple"、“ban

一、Set集合概述

Set是Java中的集合框架之一,用来存储一系列的元素。和List不同,Set中的元素不能重复,每个元素是唯一的。

Set有多个实现类,其中最常见的是HashSet和TreeSet。HashSet底层是使用HashMap实现的,而TreeSet则是使用红黑树实现的。HashSet的操作速度比较,但其元素是无序的;而TreeSet的元素是有序的,但操作速度相对较

Set的常用方法包括add()用来添加元素、remove()用来删除元素、contains()用来判断是否包含某个元素、isEmpty()用来判断集合是否为空、size()用来获取集合中元素的数量等等。

Set是一个很常用的集合框架,常用于需要存储不重复元素的场景中,如去除重复结果、判断两个集合是否相同等等。

在这里插入图片描述

二、Set集合特点

set集合的特点:

  1. 无序 没有修改方法
  2. 不可重复
    由以下代码可以看出:在这里插入图片描述

三、Set集合的遍历

set集合的遍历不像list集合遍历一样是三种遍历方式了,而是两种:

  1. foreach
  2. 迭代器(iterator)

    1、foreach

    在这里插入图片描述

2、iterator

在这里插入图片描述

四、set集合的去重

Set集合中的元素不能重复,这就天然地保证了去重的功能。当我们将多个元素添加到Set中时,如果Set中已经存在相同的元素,那么后续添加的相同元素会被自动忽略。

我们为什么要去重,因为如果是添加一个普通的一个元素的话set集合本身是可以去重的,但是如果你是添加一个对象的话他就不能去重了,为什么?因为每个对象他不是同一个地址,所以不能去重,再最后在工作的时候会用别人写的set集合的方法,你不可能叫别人去写,所以是需要自己去写的,所以才需要写set集合的去重。

例如,我们可以创建一个HashSet对象用于去重,然后将多个元素添加进去:

Set<String> set = new HashSet<>();
set.add("apple");
set.add("banana");
set.add("cherry");
set.add("apple");

最终的Set中只包含3个元素,分别是"apple"、"banana"和"cherry",而第二个"apple"因为是重复的所以被忽略了。

需要注意的是,元素的去重是基于equals()方法和hashCode()方法来进行的,如果某个类没有重写这两个方法,不能保证元素能够被正确去重。因此,在创建自己的类并将其存储在Set集合中时,需要注意它的equals()方法和hashCode()方法是否正确实现。

1、元素的去重

Set<Integer> set = new TreeSet<>();
set.add(3);
set.add(1);
set.add(2);

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

以上代码会输出1、2、3,表示TreeSet中的元素已经按照升序排序。
输出的结果如下面的一样:
在这里插入图片描述

需要注意的是,在使用SortedSet和TreeSet时,元素的排序是基于比较器的,因此需要保证比较器的正确性。另外,在使用TreeSet时,由于它是基于红黑树实现的,所以访问元素的效率比较高。

2、对象的去重

如果是没有进行任何操作就会出现以下的情况:
在这里插入图片描述
【重点】

如前面我所说的要去重,是基于equals方法和hashCode方法

五、set集合的排序

Set集合本身的特点是无序的,即元素的顺序无法保证。如果需要按照某种顺序排序,可以使用SortedSet子接口或TreeSet实现类来实现。

SortedSet是Set接口的子接口,其中的元素可以按照自然顺序或指定顺序进行排序。具体来说,SortedSet要求其中元素必须实现Comparable接口或通过Comparator进行比较。

TreeSet是SortedSet接口的实现类,它是一个基于红黑树的集合,能够保证元素有序。TreeSet提供了多个构造方法,可以用于指定元素的比较器。

例如,我们可以创建一个TreeSet对象,然后将多个元素添加进去,最后通过迭代器进行遍历:

1、自然排序接口(Comparable)

需要我们的类implements Comparable接口:

Comparable是Java中的一个接口,用于比较类的对象的大小关系。它只包含一个方法compareTo(),用于比较两个对象之间的大小关系。

在实现了Comparable接口的类中,我们可以使用compareTo()方法来对对象进行排序和查找操作。此方法返回一个整数值,表示本对象与另一个对象的大小关系。若返回值为0,则表示两个对象相等;若返回值小于0,则表示本对象小于另一个对象;若返回值大于0,则表示本对象大于另一个对象。

例如,我们可以创建一个类Address,实现Comparable接口,然后在其中重写compareTo()方法:
在这里插入图片描述

对象的


/**
 * 
 * @author tgq
 *
 */
class Person implements Comparable<Person>{
   
   
    private int id;
    private String name;
    private int money;

    public Person(int id, String name, int money) {
   
   
        super();
        this.id = id;
        this.name = name;
        this.money = money;
    }

    @Override
    public int compareTo(Person o) {
   
   
        // 升序
        return this.id - o.id;
        // 降序
        return  o.id - this.id;
    }

}

以上代码中,我们对Address类的对象按照city和street进行比较。首先按照city进行比较,如果两个对象的city相等,则按照street进行比较。这样,在使用排序方法对Address类的对象进行排序时,就会按照city和street进行排序。

需要注意的是,使用Comparable接口进行排序时,需要保证被排序的元素类实现了该接口,并且该接口的实现比较器具有可传递性,即如果a > b并且b > c,则a > c。这样可以确保排序的正确性。

2、比较器排序接口(comparator)

Comparator是Java中的一个接口,用于比较类的对象的大小关系。与Comparable不同的是,Comparator独立于被比较的类,可以定义多个比较器,并且可以在使用时动态指定比较器。

Comparator接口只包含一个方法compare(),用于比较两个对象之间的大小关系。此方法返回一个整数值,表示第一个对象与第二个对象的大小关系。若返回值为0,则表示两个对象相等;若返回值小于0,则表示第一个对象小于第二个对象;若返回值大于0,则表示第一个对象大于第二个对象。

1、单个排序

例如,在我们上一个不变的情况下,然后在其中定义多个比较器:
在这里插入图片描述

2、多个排序

在原本的基础上做出一点点的改动

在这里插入图片描述

需要注意的是,在使用Comparator进行排序时,我们需要保证比较器具有可传递性,即如果a > b并且b > c,则a > c。这样可以确保排序的正确性。

希望对你们有用!!!

相关文章
|
3月前
|
自然语言处理 前端开发 Java
JBoltAI 框架完整实操案例 在 Java 生态中快速构建大模型应用全流程实战指南
本案例基于JBoltAI框架,展示如何快速构建Java生态中的大模型应用——智能客服系统。系统面向电商平台,具备自动回答常见问题、意图识别、多轮对话理解及复杂问题转接人工等功能。采用Spring Boot+JBoltAI架构,集成向量数据库与大模型(如文心一言或通义千问)。内容涵盖需求分析、环境搭建、代码实现(知识库管理、核心服务、REST API)、前端界面开发及部署测试全流程,助你高效掌握大模型应用开发。
367 5
|
2月前
|
Oracle Java 关系型数据库
掌握Java Stream API:高效集合处理的利器
掌握Java Stream API:高效集合处理的利器
335 80
|
2月前
|
安全 Java API
Java 8 Stream API:高效集合处理的利器
Java 8 Stream API:高效集合处理的利器
223 83
|
2月前
|
并行计算 Java API
Java List 集合结合 Java 17 新特性与现代开发实践的深度解析及实战指南 Java List 集合
本文深入解析Java 17中List集合的现代用法,结合函数式编程、Stream API、密封类、模式匹配等新特性,通过实操案例讲解数据处理、并行计算、响应式编程等场景下的高级应用,帮助开发者提升集合操作效率与代码质量。
128 2
|
2月前
|
存储 缓存 NoSQL
java 集合入门基础理论的核心概念与实用长尾知识
本文介绍了Java集合框架的基础理论知识,包括单列集合(List、Set、Queue)和双列集合(Map)的特点及常用实现类(如ArrayList、HashSet、HashMap等)。详细讲解了集合的遍历方式(迭代器、增强for循环、Lambda表达式)和典型应用场景(如数据去重、键值存储等)。通过具体代码示例,帮助初学者理解集合框架的核心概念和实际应用,为Java编程中的数据存储与管理提供基础指导。
77 0
|
2月前
|
安全 Java API
Java 集合高级应用与实战技巧之高效运用方法及实战案例解析
本课程深入讲解Java集合的高级应用与实战技巧,涵盖Stream API、并行处理、Optional类、现代化Map操作、不可变集合、异步处理及高级排序等核心内容,结合丰富示例,助你掌握Java集合的高效运用,提升代码质量与开发效率。
192 0
|
2月前
|
存储 安全 Java
Java 学习路线 35 掌握 List 集合从入门到精通的 List 集合核心知识
本文详细解析Java中List集合的原理、常用实现类(如ArrayList、LinkedList)、核心方法及遍历方式,并结合数据去重、排序等实际应用场景,帮助开发者掌握List在不同业务场景下的高效使用,提升Java编程能力。
289 0
|
3月前
|
存储 缓存 安全
Java 集合容器常见面试题及详细解析
本文全面解析Java集合框架,涵盖基础概念、常见接口与类的特点及区别、底层数据结构、线程安全等内容。通过实例讲解List(如ArrayList、LinkedList)、Set(如HashSet、TreeSet)、Map(如HashMap、TreeMap)等核心组件,帮助读者深入理解集合容器的使用场景与性能优化。适合准备面试或提升开发技能的开发者阅读。
60 0
|
3月前
|
存储 缓存 安全
Java 集合篇面试题全面总结及答案解析
本文总结了Java集合框架的核心概念、常见集合类的特性与应用场景,以及开发中可能遇到的问题与解决方案。内容涵盖集合框架的基础接口(如Collection、Set、List、Map)、泛型的优点、线程安全集合类(如ConcurrentHashMap、CopyOnWriteArrayList)、常见集合类的区别(如ArrayList与LinkedList、HashMap与HashTable)等。此外,还详细介绍了如何实现LRU缓存、FIFO队列、优先级队列及栈等数据结构,并提供了相关代码示例。通过本文,读者可以全面掌握Java集合相关的面试知识点及其实际应用技巧。
127 1
|
3月前
|
缓存 Java API
Java 集合容器实操技巧与案例详解
本教程基于Java 8+新特性和现代开发实践,深入讲解Java集合容器的实操技巧。通过具体场景演示Stream API数据处理、ConcurrentHashMap并发控制、LinkedHashMap实现LRU缓存、TreeSet自定义排序等高级特性。同时涵盖computeIfAbsent优化操作、EnumMap专用集合使用、集合统计与运算(交集、并集、差集)等内容。代码示例丰富,助力掌握高效编程方法。[点击获取完整代码](https://pan.quark.cn/s/14fcf913bae6)。
57 0