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

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

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

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

Java零基础-HashSet

前言

在Java集合框架中,HashSet是一个常用的数据结构,实现了Set接口,提供了一个不允许重复元素的集合。对于Java零基础的学习者来说,理解HashSet的用法对于掌握Java集合操作至关重要。

摘要

本文将详细介绍Java中的HashSet,包括其特性、操作方法、应用场景、优缺点分析,并通过代码示例和测试用例,帮助Java零基础的学习者快速掌握HashSet的使用。

简介

HashSet是基于HashMap实现的,它继承了Set接口和AbstractSet类。由于HashSet没有维护元素的顺序,因此它在添加、删除和查找操作上提供了较高的性能。

源代码解析

以下是使用HashSet的一个简单示例:

import java.util.HashSet;
import java.util.Set;

public class HashSetExample {
    public static void main(String[] args) {
        // 创建HashSet实例
        Set<String> fruits = new HashSet<>();

        // 向HashSet添加元素
        fruits.add("Apple");
        fruits.add("Banana");
        fruits.add("Cherry");

        // 打印HashSet
        System.out.println("Fruits: " + fruits);

        // 检查HashSet是否包含某个元素
        boolean containsBanana = fruits.contains("Banana");
        System.out.println("Contains Banana: " + containsBanana);

        // 从HashSet移除元素
        fruits.remove("Banana");
        System.out.println("Fruits after removing Banana: " + fruits);

        // 获取HashSet的大小
        int size = fruits.size();
        System.out.println("Number of fruits: " + size);
    }
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.

应用场景案例

  • 去重存储:在需要存储不重复项的集合时,如用户的ID列表。
  • 集合运算:进行数学上的集合并集、交集、差集等操作。

优缺点分析

  • 优点
    • 快速的查找、添加和删除操作。
    • 没有顺序要求,实现简单。
  • 缺点
    • 不保证元素的顺序,如果需要有序集合,需要使用其他数据结构。
    • 内存占用比TreeSet大,因为HashSet基于HashMap实现。

类代码方法介绍

以下是HashSet中一些常用方法的介绍:

  • add(E e): 向集合添加一个元素。
  • remove(Object o): 从集合中移除一个元素。
  • contains(Object o): 检查集合是否包含指定元素。
  • size(): 返回集合中元素的数量。

测试用例

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

import java.util.HashSet;
import java.util.Set;

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

        // 测试添加元素
        System.out.println("添加元素后的集合: " + numbers);

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

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

        // 测试集合大小
        System.out.println("集合大小: " + numbers.size());
    }
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.

代码解析:

这段Java代码演示了HashSet的基本操作,包括添加元素、检查元素是否存在、移除元素和获取集合大小。以下是对代码的逐行解析:

import java.util.HashSet;
import java.util.Set;
  • 1.
  • 2.

导入Java的Set接口和HashSet实现类。

public class HashSetTest {
  • 1.

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

    public static void main(String[] args) {
  • 1.

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

        Set<Integer> numbers = new HashSet<>();
  • 1.

声明了一个Set接口的引用numbers并初始化为Integer类型的元素的HashSet实例。

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

使用add方法向HashSet中添加了三个整数:1、2 和 1。由于HashSet不存储重复元素,第三次添加的1不会影响集合。

        // 测试添加元素
        System.out.println("添加元素后的集合: " + numbers);
  • 1.
  • 2.

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

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

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

        // 测试移除元素
        numbers.remove(1);
  • 1.
  • 2.

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

        System.out.println("移除元素1后的集合: " + numbers);
  • 1.

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

        // 测试集合大小
        System.out.println("集合大小: " + numbers.size());
  • 1.
  • 2.

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

    }
}
  • 1.
  • 2.

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

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

全文小结

本文介绍了Java中的HashSet,包括它的基本用法、优缺点、常用方法和实际应用场景。通过代码示例和测试用例,我们学习了如何在实际编程中使用HashSet

总结

HashSet是Java集合框架中一个非常有用的数据结构,特别适合需要快速查找和去重的场景。理解HashSet的工作原理和特性,可以帮助我们在解决实际问题时做出合适的选择。希望本文能帮助Java零基础的学习者快速掌握HashSet的使用。

… …

文末

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

… …

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

wished for you successed !!!


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

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

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