java自学网VIP

Java自学网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 4382|回复: 2

【java原理分析】HashMap底层原理 源码 结构深入分析 精解

[复制链接]
  • TA的每日心情
    开心
    2021-5-25 00:00
  • 签到天数: 1917 天

    [LV.Master]出神入化

    2025

    主题

    3683

    帖子

    6万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    66151

    宣传达人突出贡献优秀版主荣誉管理论坛元老

    发表于 2015-7-25 10:32:37 | 显示全部楼层 |阅读模式
    本次要分析的java数据结构是HashMap,为什么要分析HashMap呢?废话是这么回答的:HashMap重要呗,为什么这么说因为现在大多数的互联网开发中经常会涉及到HashMap。尤其在获取数据时,在转为json格式之前,基本都是以HashMap数据类型来呈现的,在网上也看了很多关于HashMap的资料,都是感觉讲解的不是很全面,这文章有的,另外一个文章中没有,都是一块一块的。没有那么全面的,这里把自己总结的关于HashMap的底层分析和大家分享下吧。也帮助大家深入理解下HashMap,更好的学习java。. [" R. T* \- A* ?$ N3 ?% C6 D
    1、HashMap的结构:
    - }  i9 C( \2 v; U  o% @: Y" |数组与链表的结合体。
    # P8 A* V9 a, f9 ?: W  t; w4 X; s( v' @+ E  v* i4 s
    2、最直观的结构图:1 k0 A+ @* \$ Q( ]$ T1 r) C  D

      j6 L) X8 p8 U, j2 B 0_1298551673zkZg.gif
    ( Z( o5 l; p* {2 B$ I$ G4 C5 M& X2 p
    3、HashMap的结构图,每个HashMap都包含这四个属性:key,value,hash,next; Q: F/ d) t( W( _& @
    • static class Entry<K,V> implements Map.Entry<K,V> {  
    •         final K key;  
    •         V value;  
    •         final int hash;  
    •         Entry<K,V> next;  
    • ..........  
    • }  , z/ ]; @* Z* A6 V% z

    " t9 i  ]( o* G& h2 f
    * G) h7 t) R$ i. ?
    4、loadFactor为加载因子(即在达到这个值得时候会扩容),hashmap设为0.75,这是值是基于时间与空间的折中考虑的7 ?% o+ l  K9 B5 x+ Y1 l

    : w* m2 M' x* @0 {  q5、默认的数组长度是16- ]/ A: W8 v/ u9 m4 P

    ; m2 i& L7 @' t/ {, N( T
    # F' |0 ^9 I  X9 @5 V0 L9 m
    ; m' N& g8 |( [  B. ], V& z
    & u4 X' T! {% g0 \1 t; g
    6 _/ Z0 `( ^$ I, L9 V
    : J9 t" T( e9 B( a

    : ^8 r' S4 z5 O7 f$ F+ V9 w% _9 T+ n# u8 y3 n7 W' U5 g5 o
    回复

    使用道具 举报

  • TA的每日心情
    无聊
    2021-1-17 23:32
  • 签到天数: 18 天

    [LV.4]略有小成

    0

    主题

    46

    帖子

    30万

    积分

    终身VIP

    Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60Rank: 60

    积分
    300432
    发表于 2021-1-9 16:09:50 | 显示全部楼层
    插个眼,好好学习哦,天天向东航发发发
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    0

    主题

    3

    帖子

    10

    积分

    普通会员

    Rank: 2

    积分
    10
    发表于 2021-11-24 19:48:43 | 显示全部楼层
    难住我了· 我刚入门·
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|Archiver|手机版|小黑屋|Java自学网

    GMT+8, 2024-6-11 01:31 , Processed in 0.079855 second(s), 32 queries .

    Powered by Javazx

    Copyright © 2012-2022, Javazx Cloud.

    快速回复 返回顶部 返回列表