Java零基础-集合:Set

哈喽,各位小伙伴们,你们好呀,我是喵手。运营社区:C站/掘金/腾讯云;欢迎大家常来逛逛

  今天我要给大家分享一些自己日常学习到的一些知识点,并以文字的形式跟大家一起交流,互相学习,一个人虽可以走的更快,但一群人可以走的更远。

  我是一名后端开发爱好者,工作日常接触到最多的就是Java语言啦,所以我都尽量抽业余时间把自己所学到所会的,通过文章的形式进行输出,希望以这种方式帮助到更多的初学者或者想入门的小伙伴们,同时也能对自己的技术进行沉淀,加以复盘,查缺补漏。

小伙伴们在批阅的过程中,如果觉得文章不错,欢迎点赞、收藏、关注哦。三连即是对作者我写作道路上最好的鼓励与支持!

前言

在Java编程语言中,Set集合是一组不包含重复元素的接口,它对于确保数据的唯一性非常有用。对于Java初学者来说,理解Set的工作原理和应用场景是掌握Java集合框架的重要一步。

摘要

本文将引导Java零基础的学习者了解Set接口及其实现类,包括HashSetTreeSet。通过源代码解析、应用场景案例、优缺点分析、方法介绍和测试用例,本文将帮助读者全面理解Set的使用方法。

简介

Set接口继承自Collection接口,代表一组不包含重复元素的集合。Set不允许包含重复的元素,并且没有保证元素的顺序。

源代码解析

以下是使用HashSetTreeSet的简单示例:

import java.util.*;

public class SetExample {
    public static void main(String[] args) {
        // 使用HashSet
        Set<String> hashSet = new HashSet<>();
        hashSet.add("Apple");
        hashSet.add("Banana");
        hashSet.add("Orange");
        System.out.println("HashSet: " + hashSet);

        // 使用TreeSet
        Set<String> treeSet = new TreeSet<>(hashSet); // TreeSet会排序
        System.out.println("TreeSet: " + treeSet);
    }
}

应用场景案例

  • HashSet: 当你需要存储不包含重复项的集合,并且对元素的顺序没有要求时。
  • TreeSet: 当你需要存储不重复的元素,并且需要保持元素处于某种顺序(自然顺序或自定义顺序)时。

优缺点分析

  • HashSet:
    • 优点:快速查找,添加和删除元素。
    • 缺点:不保证元素的顺序。
  • TreeSet:
    • 优点:所有元素都会按照升序进行排序。
    • 缺点:排序可能导致查找、添加和删除操作相对慢一些。

类代码方法介绍

以下是Set接口中一些常用方法的介绍:

  • add(E e): 添加一个元素到集合中,如果元素已存在,则不会添加。
  • remove(Object o): 从集合中移除指定元素。
  • contains(Object o): 检查集合是否包含指定元素。
  • size(): 返回集合中元素的数量。

测试用例

以下是使用main函数编写的测试用例示例:

public class SetTest {
    public static void main(String[] args) {
        Set<Integer> set = new HashSet<>();
        set.add(1);
        set.add(2);
        set.add(1); // 重复元素,不会被添加

        // 测试添加元素
        System.out.println("添加元素后: " + set);

        // 测试元素是否存在
        System.out.println("集合是否包含元素2: " + set.contains(2));

        // 测试移除元素
        set.remove(1);
        System.out.println("移除元素1后: " + set);

        // 测试集合大小
        System.out.println("集合大小: " + set.size());
    }
}

代码解析:

这段Java代码演示了如何使用HashSet来执行基本的Set操作。以下是对代码的逐行解析:

public class SetTest {

定义了一个名为SetTest的公共类。

    public static void main(String[] args) {

定义了程序的入口点main方法,这个方法是static的,可以在不创建类实例的情况下调用。String[] args是传递给main方法的参数数组。

        Set<Integer> set = new HashSet<>();

声明了一个Set接口的引用set,并使用new HashSet<>()创建了它的一个HashSet实例。HashSet是一个实现了Set接口的类,用于存储整数(Integer类型)的集合,且集合中的元素不重复。

        set.add(1);
        set.add(2);
        set.add(1); // 重复元素,不会被添加

使用add方法尝试向set中添加三个整数:1、2和1。由于Set不允许重复元素,所以第二次添加1不会有任何效果,set中仍然只有一个1。

        // 测试添加元素
        System.out.println("添加元素后: " + set);

打印添加元素后的集合内容。此时集合中应该包含[1, 2]。

        // 测试元素是否存在
        System.out.println("集合是否包含元素2: " + set.contains(2));

使用contains方法检查集合中是否包含元素2,并打印结果。由于集合中确实包含2,所以输出应为true

        // 测试移除元素
        set.remove(1);

使用remove方法移除集合中的元素1。

        System.out.println("移除元素1后: " + set);

打印移除元素1后的集合内容。此时集合中应该只包含[2]。

        // 测试集合大小
        System.out.println("集合大小: " + set.size());

打印集合的当前大小。移除元素1后,集合大小应该为1。

    }
}

结束main方法和SetTest类的定义。

当这段代码运行时,它将展示如何在HashSet中添加元素、检查元素是否存在、移除元素以及获取集合的大小。这是对Java Set操作的基础演示,适合初学者理解Set的基本用法。

全文小结

本文介绍了Java中的Set接口及其两个主要实现类HashSetTreeSet。我们学习了它们的基本用法、优缺点以及适用场景。

总结

Java的Set集合为确保数据的唯一性提供了一种有效的方式。理解Set的不同实现及其特性,可以帮助我们在实际编程中做出更合适的选择。希望本文能帮助Java零基础的学习者快速入门Set的使用。

… …

文末

好啦,以上就是我这期的全部内容,如果有任何疑问,欢迎下方留言哦,咱们下期见。

… …

学习不分先后,知识不分多少;事无巨细,当以虚心求教;三人行,必有我师焉!!!

wished for you successed !!!


⭐️若喜欢我,就请关注我叭。

⭐️若对您有用,就请点赞叭。

⭐️若有疑问,就请评论留言告诉我叭。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值