广告
返回顶部
首页 > 资讯 > 精选 >Java的集合函数HashMap怎么用
  • 261
分享到

Java的集合函数HashMap怎么用

2023-06-26 06:06:29 261人浏览 独家记忆
摘要

本篇内容介绍了“Java的集合函数HashMap怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!概述①以数组+链表+红黑树实现。主要用来

本篇内容介绍了“Java的集合函数HashMap怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

概述

以数组+链表+红黑树实现。主要用来处理具有键值对特征的数据。
②当链表长度大于阈值(或者红黑树的边界值,默认为 8 )并且当前数组的长度大于 64 时,此时此索引位置上的所有数据改为使用红黑树存储。
补充:链表转换成红黑树前会判断,即便阈值大于 8,但是数组长度小于 64,此时并不会将链表变为红黑树,而是选择逬行数组扩容。
④每个node节点存储着用来定位数据索引位置的hash值,K键,V值以及指向链表下一个节点的Node<K,V> next节点组成。
⑤Node是HashMap的内部类,实现了Map.Entry接口,本质是一个键值对。
⑥这样做的目的是因为数组比较小,尽量避开红黑树结构,这种情况下变为红黑树结构,反而会降低效率,因为红黑树需要逬行左旋,右旋,变色这些操作来保持平衡。同时数组长度小于64时,搜索时间相对要快些。所以结上所述为了提高性能和减少搜索时间,底层阈值大于8并且数组长度大于64时,链表才转换为红黑树。

Java的集合函数HashMap怎么用

重要的参数

①容量(Capacity)和负载因子(Load factor
②初始容量:容量是哈希表中桶的个数,初始容量是创建哈希表时的容量。
③负载因子:负载因子是衡量哈希表在自动增加容量之前允许其达到多满的指标。 默认0.75
④threshold:threshold表示所能容纳的键值对的临界值。计算公式为 数组长度 * 负载因子。
⑤size:size是hashmap中实际存在的键值对数量。
⑥modCount:用来记录hashmap内部结构发生变化的次数。

put函数的实现

大致思路:

对key的hashCode()做hash,然后再计算index;
如果没碰撞直接放到bucket里;
如果碰撞了,以链表的形式存在buckets后;
如果碰撞导致链表过长(大于等于 TREEIFY_THRESHOLD )就把链表转换成红黑树;
如果节点已经存在就替换old value(保证key的唯一性)
如果bucket满了(超过 load factor*current capacity ),就要resize(调整大小)。

get函数的实现

大致思路:

  • bucket里的第一个节点,直接命中;

  • 如果有冲突,则通过key.equals(k)去查找对应的entry若为树,则在树中通过key.equals(k)查找,O(logn);若为链表,则在链表中通过key.equals(k)查找,O(n)。

hash函数的实现

//高16bit不变,低16bit和高16bit做了一个异或static final int hash(Object key) {    int h;    return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);}

获取HashMap的元素时,基本分两步:

  • 首先根据hashCode()做hash,然后确定bucket的index;

  • 如果bucket的节点的key不是我们需要的,则通过keys.equals()在链表(红黑树)中找。

RESIZE的实现

当put时,如果发现目前的bucket占用程度已经超过了Load Factor所希望的比例,那么就会发生resize。

Java的集合函数HashMap怎么用

resize的过程,简单的说就是把bucket扩充为2倍,之后重
新计算index,把节点再放到新的bucket中。元素的位置要么是在原位置,要么是在原位置再移动2次幂的位置。省去了重新计算hash值的时间,把之前的冲突的节点分散到新的bucket了

Java的集合函数HashMap怎么用

什么时候会使用HashMap?他有什么特点?

是基于Map接口的实现,存储键值对时,它可以接收null的键值,是非同步的,HashMap存储着Entry(hash, key, value, next)对象。
** 你知道HashMap的工作原理吗?**
通过hash的方法,通过put和get存储和获取对象。存储对象时,我们将K/V传给put方法时,它调用hashCode计算hash从而得到bucket位置,进一步存储,HashMapJava集合&mdash;&mdash;HashMap会根据当前bucket的占用情况自动调整容量(超过 Load Facotr 则resize为原来的2倍)。获取对象时,我们将K传给get,它调用hashCode计算hash从而得到bucket位置,并进一步调用equals()方法确定键值对。如果发生碰撞的时候,Hashmap通过链表将产生碰撞冲突的元素组织起来,在Java 8中,如果一个bucket中碰撞冲突的元素超过某个限制(默认是8),则使用红黑树来替换链表,从而提高速度。

你知道get和put的原理吗?equals()和hashCode()的都有什么作用?

通过对key的hashCode()进行hashing,并计算下标( (n-1) & hash ),从而获得buckets的位置。如果产生碰撞,则利用key.equals()方法去链表或树中去查找对应的节点。

hash的实现,为什么要这样实现?

在Java 1.8的实现中,是通过hashCode()的高16位异或低16位实现的: (h =k.hashCode()) ^ (h >>> 16) ,主要是从速度、功效、质量来考虑的,这么做可以在bucket的n比较小的时候,也能保证考虑到高低bit都参与到hash的计算中,同时不会有太大的开销。

如果HashMap的大小超过了负载因子( load factor )定义的容量,怎么办?

如果超过了负载因子(默认0.75),则会重新resize一个原来长度两倍的HashMap,并且重新调用hash方法。

“Java的集合函数HashMap怎么用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

--结束END--

本文标题: Java的集合函数HashMap怎么用

本文链接: https://www.lsjlt.com/news/307078.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java的集合函数HashMap怎么用
    本篇内容介绍了“Java的集合函数HashMap怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!概述①以数组+链表+红黑树实现。主要用来...
    99+
    2023-06-26
  • Java中HashMap集合的常用方法详解
    目录public Object clone()总结public Object clone() 返回hashMap集合的副本   其余的方法都是实现Map...
    99+
    2022-11-12
  • 分析Java中HashMap集合的常用方法
    这篇文章主要介绍“分析Java中HashMap集合的常用方法”,在日常操作中,相信很多人在分析Java中HashMap集合的常用方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”分析Java中HashMap集...
    99+
    2023-06-25
  • 利用Java如何实现对HashMap的集合使用
    这期内容当中小编将会给大家带来有关利用Java如何实现对HashMap的集合使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。HashMap是最常用的Map集合,它的键值对在存储时要根据键的哈希码来确定值...
    99+
    2023-05-31
    java 集合 hashmap
  • MySQL中集合函数怎么用
    这篇文章将为大家详细讲解有关MySQL中集合函数怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。到现在为止,你只学习了如何根据特定的条件从表中取出一条或多条记录。但是...
    99+
    2022-10-19
  • Java中Map集合的双列集合怎么用
    这篇文章给大家分享的是有关Java中Map集合的双列集合怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Map集合Map概述Map是一种依照键(key)存储元素的容器,键(key)很像下标,在List中下标是...
    99+
    2023-06-25
  • Java集合类怎么使用
    这篇文章主要讲解了“Java集合类怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java集合类怎么使用”吧!初始容量集合是我们在Java编程中使用非常广泛的,它就像大海,海纳百川,像...
    99+
    2023-06-02
  • Java中的set集合怎么应用
    这篇文章主要讲解了“Java中的set集合怎么应用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中的set集合怎么应用”吧!Set系类集合特点:无序:存取顺序不一致不重复:可以去除重...
    99+
    2023-07-02
  • java中map集合怎么使用
    在Java中,Map是一种键值对的集合,它提供了一种将键映射到值的方式。Map接口是Java集合框架中的一部分,它有多个实现类,例如...
    99+
    2023-10-08
    java
  • Java Collection集合的ArrayList和HashSet怎么用
    今天小编给大家分享一下Java Collection集合的ArrayList和HashSet怎么用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我...
    99+
    2023-06-29
  • Java集合的Queue和LinkedList怎么使用
    这篇文章主要讲解了“Java集合的Queue和LinkedList怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java集合的Queue和LinkedList怎么使用”吧!Linke...
    99+
    2023-06-02
  • 利用java怎么对集合的子集进行求解
    利用java怎么对集合的子集进行求解?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。 java求解集合的子集的实例方式1:我们知道子集个数 2的n次方比如a,b,c...
    99+
    2023-05-31
    java ava
  • java怎么用redisTemplate的Operations存取list集合
    这篇文章主要讲解了“java怎么用redisTemplate的Operations存取list集合”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“java怎么用redisTemplate的Op...
    99+
    2023-06-20
  • java怎么给实体类集合加数据
    要给实体类集合添加数据,可以使用以下步骤:1. 创建一个实体类,并定义其属性。2. 创建一个集合对象,用来存储实体类的对象。比如使用...
    99+
    2023-09-25
    java
  • mysql 聚合函数怎么用
    mysql 聚合函数怎么用?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!mysql聚合函数用法:1、使用SELECT...
    99+
    2022-10-18
  • Java的CopyOnWrite集合有什么用
    这篇文章主要介绍“Java的CopyOnWrite集合有什么用”,在日常操作中,相信很多人在Java的CopyOnWrite集合有什么用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的CopyOnWr...
    99+
    2023-06-03
  • MySQL中的聚合函数怎么用
    本篇内容介绍了“MySQL中的聚合函数怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,...
    99+
    2022-10-19
  • Java集合HashSet,TreeSet与LinkedHashSet怎么使用
    本篇内容介绍了“Java集合HashSet,TreeSet与LinkedHashSet怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!...
    99+
    2023-06-02
  • Java Properties作为集合的方法怎么使用
    这篇“Java Properties作为集合的方法怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Java&...
    99+
    2023-07-04
  • 怎么在java中将集合转换成数组
    怎么在java中将集合转换成数组?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客户端...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作