028-86922220

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

如何进行HashMap源码分析

这篇文章将为大家详细讲解有关如何进行HashMap源码分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

创新互联是一家专注于成都网站建设、网站设计绵阳电信机房的网络公司,有着丰富的建站经验和案例。

代码基于JDK 1.8

基数知识

Map是保存了Key-Value键值对的数据集合接口。HashMap是基于HashCode的Map实现。因为基于Key的HashCode进行存储,所以HashMap中Key都是唯一的。

源码解析

类声明

1
2
3
public class HashMap extends AbstractMap implements Map, Cloneable, Serializable {
   // ...
}

数据结构

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
/**
* table, 在初次使用时进行初始化, 必要时进行大小调整。
* 在分配大小时,长度总是 2的幂
*/
transient Node[] table;


// Node静态内部类,链表数据结构
static class Node implements Map.Entry {
   final int hash;
   final K key;
   V value;
   Node next;
   Node(int hash, K key, V value, Node next) {
       this.hash = hash;
       this.key = key;
       this.value = value;
       this.next = next;
   }
}

上面代码描述了HashMap的底层数据结构:数组 + 链表

在1.8中,增加了红黑树,带详细研究…

构造函数

对于构造函数,提供了多个重载,以方便创建实例:

1
2
3
4
public HashMap()
public HashMap(int initialCapacity)
public HashMap(int initialCapacity, float loadFactor)
public HashMap(Map m)

在构造函数中,initialCapacityloadFactor两个参数对map的性能有很大的影响。

1
i = (n - 1) & h;

计算key在table中的索引,h为key的hashcode,n为当前table的大小。

HashMap为非线程安全Map,其中key和value均可以为null。

关于如何进行HashMap源码分析就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


分享标题:如何进行HashMap源码分析
标题链接:http://www.tsicrk.com/article/ihjhsp.html

其他资讯

让你的专属顾问为你服务

0.6401s