Java HashSet(散列集),HashMap(散列映射)的简单介绍

Java HashSet 和 HashMap 的简单介绍

HashSet

HashSet 是集合框架的一部分,它实现了 Set 接口,用于存储一个没有重复元素的集合。它通过散列表(Hash table)实现,散列表可以看作是一个数组(Array),数组中的元素是链表(LinkedList),每个元素称为“桶(bucket)”,桶中存储的是元素的值。

HashSet 的基本操作包括添加(add)、删除(remove)、查找(contains)和遍历(iterator)。具有 O(1) 的时间复杂度。

示例 1:添加元素,代码如下:

import java.util.HashSet;

public class HashSetExample {
    public static void main(String[] args) {
        HashSet<String> set = new HashSet<String>();
        set.add("Java");
        set.add("Python");
        set.add("C#");
        set.add("PHP");
        set.add("Ruby");
        System.out.println(set);
    }
}

运行结果:

[Python, PHP, Java, C#, Ruby]

示例 2:遍历元素,代码如下:

import java.util.HashSet;
import java.util.Iterator;

public class HashSetExample {
    public static void main(String[] args) {
        HashSet<String> set = new HashSet<String>();
        set.add("Java");
        set.add("Python");
        set.add("C#");
        set.add("PHP");
        set.add("Ruby");
        Iterator<String> it = set.iterator();
        while(it.hasNext()) {
            System.out.println(it.next());
        }
    }
}

运行结果:

Python
PHP
Java
C#
Ruby

HashMap

HashMap 也是集合框架的一部分,它实现了 Map 接口,用于存储一组键值对,每个键值对称为一个 entry(条目)。它也通过散列表实现,其中键值对的键称为“散列码(hash code)”,它的作用是将键值对存储到散列表中的桶中。

HashMap 的基本操作包括添加(put)、删除(remove)、查找(get)和遍历(entrySet)。具有 O(1) 的时间复杂度。

示例 1:添加键值对,代码如下:

import java.util.HashMap;

public class HashMapExample {
    public static void main(String[] args) {
        HashMap<String, Integer> map = new HashMap<String, Integer>();
        map.put("Java", 1);
        map.put("Python", 2);
        map.put("C#", 3);
        map.put("PHP", 4);
        map.put("Ruby", 5);
        System.out.println(map);
    }
}

运行结果:

{C#=3, Ruby=5, PHP=4, Java=1, Python=2}

示例 2:遍历键值对,代码如下:

import java.util.HashMap;
import java.util.Map;

public class HashMapExample {
    public static void main(String[] args) {
        HashMap<String, Integer> map = new HashMap<String, Integer>();
        map.put("Java", 1);
        map.put("Python", 2);
        map.put("C#", 3);
        map.put("PHP", 4);
        map.put("Ruby", 5);
        for (Map.Entry<String, Integer> entry : map.entrySet()) {
            System.out.println(entry.getKey() + " = " + entry.getValue());
        }
    }
}

运行结果:

C# = 3
Ruby = 5
PHP = 4
Java = 1
Python = 2

以上就是 Java HashSet 和 HashMap 简单介绍的攻略,希望能对你有所帮助。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java HashSet(散列集),HashMap(散列映射)的简单介绍 - Python技术站

(0)
上一篇 2023年5月26日
下一篇 2023年5月26日

相关文章

  • Spring Security内置过滤器的维护方法

    Spring Security 是一款基于 Servlet Filter 的安全框架,它提供了许多内置的过滤器来实现各种不同的安全策略。本文将详细讲解 Spring Security 内置过滤器的维护方法,以帮助开发者更好地使用 Spring Security。 什么是 Spring Security 内置过滤器? Spring Security 内置了许多…

    Java 2023年5月20日
    00
  • 分享几款linux下常见的vps控制面板

    Linux下有许多VPS(Virtual Private Server,虚拟专用服务器)控制面板可供选择。这些控制面板可以帮助用户通过图形用户界面(GUI)而非命令行来对服务器进行管理。下面将介绍几种在Linux系统下常见的VPS控制面板的安装步骤和使用方法。 1. cPanel cPanel是一个流行的基于Web的Linux控制面板,适用于VPS和独立服务…

    Java 2023年5月19日
    00
  • Spring Boot接口幂等插件用法示例解析

    Spring Boot接口幂等插件用法示例解析攻略 本文将详细介绍Spring Boot接口幂等插件的用法,并给出两个实例说明。 1. 简介 在分布式的应用中,为了保障数据的一致性,常常需要保证接口的幂等性。Spring Boot提供一个开源插件spring-boot-starter-idempotency来保证这一点。 该插件使用Redis来实现幂等性的检…

    Java 2023年5月26日
    00
  • MVC默认路由实现分页(PagerExtend.dll下载)

    我来给你讲解一下“MVC默认路由实现分页(PagerExtend.dll下载)”的完整攻略。 简介 在MVC项目中,实现分页功能是非常常见的需求。PagerExtend.dll是一个实现分页的工具库,它可以帮助我们在MVC项目中快速地实现分页功能。 使用步骤 1. 下载PagerExtend.dll 首先,我们需要从官网或者其他可靠来源下载PagerExte…

    Java 2023年5月19日
    00
  • Java实现英文句子中的单词顺序逆序输出的方法

    Java实现英文句子中的单词顺序逆序输出的方法 问题描述 如何实现逆序输出英文句子中的单词顺序? 解决方案 思路 我们可以将英文句子中的所有单词转换为一个字符串数组,然后将该数组中的每一个单词逆序输出即可。 具体实现思路如下: 定义一个字符串变量,用于存储英文句子。 将英文句子按空格分割成字符串数组。 遍历字符串数组,将每一个单词逆序输出。 将逆序后的单词连…

    Java 2023年5月26日
    00
  • JDBC 入门(三)

    JDBC 入门(三)主要讲解了如何执行数据库的查询操作以及如何获取查询结果。以下是具体的完整攻略。 JDBC 查询操作 我们在学习 JDBC 操作数据库时,通常都是要进行数据的查询、更新、插入和删除操作。这里我们将讲解如何进行查询操作。 查询示例 下面是一段查询 MySQL 数据库中的 user 表,并将结果打印出来的示例代码。 import java.sq…

    Java 2023年6月15日
    00
  • Struts2之Validator验证框架的详细介绍

    Struts2之Validator验证框架详细介绍 Validator是Struts2的核心验证框架之一,它通过在Action中添加验证规则来确认表单数据的有效性。Validator提供了大量的验证方法,比如检查字符串长度、格式、是否为空等等。 常用验证方法 Validator提供了许多常用的验证方法,常用的方法如下: required:检查字段必填 str…

    Java 2023年5月20日
    00
  • Java内嵌的作用是什么?

    Java内嵌指的是在一个Java程序中嵌入其他语言的代码或脚本执行。Java内嵌的作用主要包括: 可以让Java程序具有更高的灵活性和扩展性,可通过与其他语言的混合编程实现Java程序的定制化需求; 可以利用其他语言的特性和库,快速地实现某些复杂的功能。 下面通过两个示例来说明Java内嵌的具体使用方法。 示例1:Java内嵌Python脚本 Java内置了…

    Java 2023年5月11日
    00
合作推广
合作推广
分享本页
返回顶部