JavaSE学习:HashMap

存储结构

HashMap是非常常用的数据结构之一,由数组链表组合构成。

注:以下内容基于JDK1.8

HashMap内部实际是一个 Node 类型的数组 table,每一个Node存储着键值对hash值以及next节点一共四个字段,从 next 字段我们可以看出 Node 是一个链表。Node<K, V>[]数组中的每个位置被当成一个,一个桶存放一个链表。

    static class Node<K,V> implements Map.Entry<K,V> {
        final int hash;
        final K key;
        V value;
        Node<K,V> next;

在这里插入图片描述


put()操作

确定桶下标
  • 计算hash值:调用put(K, V)方法时,根据键Key去计算hash值
  • 取模:确定桶下标的最后一步是将 key 的 hash 值对桶个数取模:hash % capacity。

:我们知道,位运算比求模运算效率高很多,如果能保证 capacity 为 2 的 n 次方,那么就可以将取模操作转换为位运算。如下:

x   : 00010000
x-1 : 00001111
------------------------
y       : 10110010
x-1     : 00001111
------------------------
y & (x - 1) : 00000010
y   : 10110010
x   : 00010000
------------------------
y % x : 00000010

由于哈希本身就存在概率性,即使两个不同键,它们的hash值有一定的概率会一样,因此会对应到同一个桶下标,这时就形成链表了。

注:JDK1.8之前,新的Node插入链表时采用头插法;JDK1.8及之后采用尾插法


扩容

为什么扩容

设 HashMap 的 table 长度为 M,需要存储的键值对数量为 N,如果哈希函数满足均匀性的要求,那么每条链表的长度大约为 N/M,因此查找的复杂度为 O(N/M)。

为了让查找的成本降低,应该使 N/M 尽可能小,因此需要保证 M 尽可能大,也就是说 table 要尽可能大。HashMap 采用动态扩容来根据当前的 N 值来调整 M 值,使得空间效率和时间效率都能得到保证。

如何扩容

HashMap数组长度默认值为16(保证为2的n次方,原因上面已经说过了):

    /**
     * The default initial capacity - MUST be a power of two.
     */
    static final int DEFAULT_INITIAL_CAPACITY = 1 << 4; // aka 16

负载因子的默认值为0.75f:比如当前的容量大小为100,当你存进第76个键值对的时候,那就进行扩容了

    /**
     * The load factor used when none specified in constructor.
     */
    static final float DEFAULT_LOAD_FACTOR = 0.75f;

进行扩容时,会重新创建一个table,并将capacity容量设为原来的两倍(仍然保持为2的n次方),然后把原table中所有键值对重新插入扩容之后的table中,因此是很费时的。

需要注意的是,扩容会遍历原来的table,重新计算hash值(因为table的长度扩大为两倍之后,确定桶下标的规则也随之改变了!)。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
单片微型计算机(MCU)经过多年的发展,在性能上有很大的进步,在型号上发展到上千种类,已经广泛应用于人类社会生活的各个领域。单片机课程已经成为高校计算机、自动化、测控以及电子信息工程等专业的重要课程。该课程是一门理论性和实践性都很强的课程,在实际教学中,应将理论教学和实验教学紧密结合。学生在掌握理论知识之余,必须通过编写程序、设计硬件电路、仿真、调试这一系列的实验过程,才能更好地掌握单片机的结构原理和应用技能。随着单片机及其接口技术的飞速发展,目前市场上供应的编程仿真实验资源并不能完全满足高校单片机课程教与学的需求,构建低成本、技术先进、源码公开的单片机编程仿真实验系统,对我国单片机课程的教学和单片机领域人才的培养具有重要的现实意义。 本论文结合目前教学中对单片机编程仿真实验系统的实际需求,采用模块化结构设计思想,精心设计和开发了单片机编程仿真实验系统。该单片机编程仿真实验系统由PC机端单片机编程控制软件和单片机编程仿真实验板两部分组成。PC机端的单片机编程控制软件可以自动检测到连接到单片机编程仿真实验板上的单片机,控制单片机编程器擦除、写入、读出、校验目标单片机ROM中的程序,以十六进制文件(.HEX文件)格式显示在控制界面内;单片机仿真实验系统能够把写入单片机的程序实时地运行,并呈现实际运行效果。单片机编程控制软件和单片机仿真实验板组成一个完整的单片机编程仿真实验系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值