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

2023-12-11java编程
12

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 简单介绍的攻略,希望能对你有所帮助。

The End

相关推荐

一文带你掌握Java8中Lambda表达式 函数式接口及方法构造器数组的引用
Lambda表达式是Java 8中引入的新特性之一,它是一个匿名函数,可以捕获参数并表现为一个代码块,而不像方法一样需要一个固定的名称。它主要用于传递行为或代码块以及事件处理等操作。...
2023-12-11 java编程
30

基于Java 谈回调函数
下面为您详细讲解基于Java的回调函数。...
2023-12-11 java编程
21

java equals函数用法详解
在Java中,equals()是用来比较两个对象是否相等的函数。equals()方法是Object类中的方法,因此所有Java类都包含equals()方法。在默认情况下,equals()方法比较对象的引用地址是否相同,即两个对象是否是同一个实例。但是,我们可以覆盖equals()方法,来定义自...
2023-12-11 java编程
63

JavaWeb学习笔记分享(必看篇)
JavaWeb是Java在Web领域的应用,是目前非常热门的技术之一。但是JavaWeb涉及到的技术非常广泛,初学者很容易迷失方向。本文总结了JavaWeb的基础知识,为初学者提供了一份学习笔记分享,希望能够帮助大家快速入门。...
2023-12-11 java编程
8

Java中replace、replaceAll和replaceFirst函数的用法小结
在Java编程中,字符串操作是很常见的,而替换字符串是其中常用的操作之一。Java提供了三种函数用于替换字符串:replace、replaceAll和replaceFirst。这篇文章将为您详细介绍它们的用法。...
2023-12-11 java编程
121

基于Java中进制的转换函数详解
进制是数学中一种表示数值大小的方法,常见的进制有10进制、2进制、16进制等。...
2023-12-11 java编程
45