学习Java HashMap,看这篇就够了

HashMap 是一个散列表,它存储的内容是键值对(key-value)映射。

HashMap 实现了 Map 接口,根据键的 HashCode 值存储数据,具有很快的访问速度,最多允许一条记录的键为 null,不支持线程同步。

HashMap 是无序的,即不会记录插入的顺序。

HashMap 继承于AbstractMap,实现了 Map、Cloneable、java.io.Serializable 接口。

HashMap 的 key 与 value 类型可以相同也可以不同,可以是字符串(String)类型的 key 和 value,也可以是整型(Integer)的 key 和字符串(String)类型的 value。

HashMap 中的元素实际上是对象,一些常见的基本类型可以使用它的包装类。

基本类型对应的包装类表如下:

基本类型 引用类型
boolean Boolean
byte Byte
short Short
int Integer
long Long
float Float
double Double
char Character

HashMap 类位于 java.util 包中,使用前需要引入它,语法格式如下

import java.util.HashMap; // 引入 HashMap 类

以下实例我们创建一个 HashMap 对象 Sites, 整型(Integer)的 key 和字符串(String)类型的 value:

HashMap<Integer, String> Sites = new HashMap<Integer, String>();

添加元素

HashMap 类提供类很多有用的方法,添加键值对(key-value)可以使用 put() 方法:

// 引入 HashMap 类
import java.util.HashMap;

public class RunoobTest {
 public static void main(String[] args) {
  // 创建 HashMap 对象 Sites
  HashMap<Integer, String> Sites = new HashMap<Integer, String>();
  // 添加键值对
  Sites.put(1, "Google");
  Sites.put(2, "Runoob");
  Sites.put(3, "Taobao");
  Sites.put(4, "Zhihu");
  System.out.println(Sites);
 }
}

执行以上代码,输出结果如下:

{1=Google, 2=Runoob, 3=Taobao, 4=Zhihu}

以下实例创建一个整型(String)的 key 和 整型(String)的 value:

// 引入 HashMap 类
import java.util.HashMap;

public class RunoobTest {
 public static void main(String[] args) {
  // 创建 HashMap 对象 Sites
  HashMap<String, String> Sites = new HashMap<String, String>();
  // 添加键值对
  Sites.put("one", "Google");
  Sites.put("two", "Runoob");
  Sites.put("three", "Taobao");
  Sites.put("four", "Zhihu");
  System.out.println(Sites);
 }
}

执行以上代码,输出结果如下:

{four=Zhihu, one=Google, two=Runoob, three=Taobao}

访问元素

我们可以使用 get(key) 方法来获取 key 对应的 value:

// 引入 HashMap 类
import java.util.HashMap;

public class RunoobTest {
 public static void main(String[] args) {
  // 创建 HashMap 对象 Sites
  HashMap<Integer, String> Sites = new HashMap<Integer, String>();
  // 添加键值对
  Sites.put(1, "Google");
  Sites.put(2, "Runoob");
  Sites.put(3, "Taobao");
  Sites.put(4, "Zhihu");
  System.out.println(Sites.get(3));
 }
}

执行以上代码,输出结果如下:

Taobao

删除元素

我们可以使用 remove(key) 方法来删除 key 对应的键值对(key-value):

// 引入 HashMap 类
import java.util.HashMap;

public class RunoobTest {
 public static void main(String[] args) {
  // 创建 HashMap 对象 Sites
  HashMap<Integer, String> Sites = new HashMap<Integer, String>();
  // 添加键值对
  Sites.put(1, "Google");
  Sites.put(2, "Runoob");
  Sites.put(3, "Taobao");
  Sites.put(4, "Zhihu");
  Sites.remove(4);
  System.out.println(Sites);
 }
}

执行以上代码,输出结果如下:

{1=Google, 2=Runoob, 3=Taobao}

删除所有键值对(key-value)可以使用 clear 方法:

// 引入 HashMap 类
import java.util.HashMap;

public class RunoobTest {
 public static void main(String[] args) {
  // 创建 HashMap 对象 Sites
  HashMap<Integer, String> Sites = new HashMap<Integer, String>();
  // 添加键值对
  Sites.put(1, "Google");
  Sites.put(2, "Runoob");
  Sites.put(3, "Taobao");
  Sites.put(4, "Zhihu");
  Sites.clear();
  System.out.println(Sites);
 }
}

执行以上代码,输出结果如下:

{}

计算大小

如果要计算 HashMap 中的元素数量可以使用 size() 方法:

// 引入 HashMap 类
import java.util.HashMap;

public class RunoobTest {
 public static void main(String[] args) {
  // 创建 HashMap 对象 Sites
  HashMap<Integer, String> Sites = new HashMap<Integer, String>();
  // 添加键值对
  Sites.put(1, "Google");
  Sites.put(2, "Runoob");
  Sites.put(3, "Taobao");
  Sites.put(4, "Zhihu");
  System.out.println(Sites.size());
 }
}

执行以上代码,输出结果如下:

4

迭代 HashMap

可以使用 for-each 来迭代 HashMap 中的元素。

如果你只想获取 key,可以使用 keySet() 方法,如果你只想获取 value,可以使用 values() 方法。

// 引入 HashMap 类
import java.util.HashMap;

public class RunoobTest {
 public static void main(String[] args) {
  // 创建 HashMap 对象 Sites
  HashMap<Integer, String> Sites = new HashMap<Integer, String>();
  // 添加键值对
  Sites.put(1, "Google");
  Sites.put(2, "Runoob");
  Sites.put(3, "Taobao");
  Sites.put(4, "Zhihu");
  // 输出 key 和 value
  for (Integer i : Sites.keySet()) {
   System.out.println("key: " + i + " value: " + Sites.get(i));
  }
 }
}

执行以上代码,输出结果如下:

key: 1 value: Google
key: 2 value: Runoob
key: 3 value: Taobao
key: 4 value: Zhihu

以上就是详解Java HashMap的详细内容,更多关于Java HashMap的资料请关注我们其它相关文章!

(0)

相关推荐

  • Java HashMap 如何正确遍历并删除元素的方法小结

    (一)HashMap的遍历 HashMap的遍历主要有两种方式: 第一种采用的是foreach模式,适用于不需要修改HashMap内元素的遍历,只需要获取元素的键/值的情况. HashMap<K, V> myHashMap; for (Map.entry<K, V> item : myHashMap.entrySet()){ K key = item.getKey(); V val = item.getValue(); //todo with key and val //WARNI

  • Java HashMap三种循环遍历方式及其性能对比实例分析

    本文实例讲述了Java HashMap三种循环遍历方式及其性能对比.分享给大家供大家参考,具体如下: HashMap的三种遍历方式 (1)for each map.entrySet() Map<String, String> map = new HashMap<String, String>(); for (Entry<String, String> entry : map.entrySet()) { entry.getKey(); entry.getValue();

  • Java HashMap两种简便排序方法解析

    这篇文章主要介绍了Java HashMap两种简便排序方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 HashMap的储存是没有顺序的,而是按照key的HashCode实现. key=手机品牌,value=价格,这里以这个例子实现按名称排序和按价格排序. Map phone=new HashMap(); phone.put("Apple",8899); phone.put("SAMSUNG",7000);

  • Java实现简易HashMap功能详解

    本文实例讲述了Java实现简易HashMap功能.分享给大家供大家参考,具体如下: 创建节点类 节点类含有的属性:键值对(value,key)以及指向下一节点的next: 这些属性的get以及set方法 代码如下: /** * 节点类 * @author HP * */ public class Node { private Object value; private Object key; private Node next; /** * 空节点 */ public Node() { } /*

  • Java5种遍历HashMap数据的写法

    本文介绍了最好的Java5种遍历HashMap数据的写法,分享给大家,也给自己留一个笔记,具体如下: 通过EntrySet的迭代器遍历 Iterator < Entry < Integer, String >> iterator = coursesMap.entrySet().iterator(); while (iterator.hasNext()) { Entry < Integer, String > entry = iterator.next(); System

  • java在hashmap初始化时赋初值过程解析

    Java中的HashMap是一种常用的数据结构,一般用来做数据字典或者Hash查找的容器. 一般我们初始化并赋初值是这样做的: HashMap<String, Object> map = new HashMap<>(); map.put("name", "yanggb"); map.put("lover", "huangq"); 但是有时候我们会想在一个表达式中完成初始化并赋初值的操作: HashMap

  • 在Java中如何决定使用 HashMap 还是 TreeMap

    HashMap简单总结: 1.HashMap 是链式数组(存储链表的数组)实现查询速度可以,而且能快速的获取key对应的value: 2.查询速度的影响因素有 容量和负载因子,容量大负载因子小查询速度快但浪费空间,反之则相反: 3.数组的index值是(key 关键字, hashcode为key的哈希值, len 数组的大小):hashcode%len的值来确定,如果容量大负载因子小则index相同(index相同也就是指向了同一个桶)的概率小,链表长度小则查询速度快,反之index相同的概率大

  • Java手写简易版HashMap的使用(存储+查找)

    HashMap的基本结构 package com.liuyuhe; public class Node { int hash; Object key; Object value; Node next; } package com.liuyuhe; public class MyHashMap { Node[] table; //位桶数组 int size; //存放键值对的个数 public MyHashMap() { table=new Node[16]; } } put()方法存储键值对 p

  • JAVA--HashMap热门面试题

    1. 为什么我们建议在定义HashMap的时候,就指定它的初始化大小呢? 答:在当我们对HashMap初始化时,如果没有为其设置初始化容量,那么系统会默认创建一个容量为16的大小的集合.当我们向HashMap中添加元素时,如果HashMap的容量值超过了它的临界值(默认16*0.75=12)时,(0.75是HashMap的加载因子)HashMap将会重新扩容到下一个2的指数次幂(2^4=16 下一个2的指数次幂是2^5=32).由于HashMap扩容要进行resize的操作,频繁的resize,

  • Java中遍历ConcurrentHashMap的四种方式详解

    这篇文章主要介绍了Java中遍历ConcurrentHashMap的四种方式详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 方式一:在for-each循环中使用entries来遍历 System.out.println("方式一:在for-each循环中使用entries来遍历");for (Map.Entry<String, String> entry: map.entrySet()) { System.out.pr

随机推荐