HashMap深度分析.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
HashMap深度分析.doc

java.util.HashMap是很常见的类,前段时间公司系统由于对HashMap使用不当,导致cpu百分之百,在并发环境下使用HashMap 而没有做同步,可能会引起死循环,关于这一点,sun的官方网站上已有阐述,这并非是bug。 HashMap的数据结构 ???????? HashMap主要是用数组来存储数据的,我们都知道它会对key进行哈希运算,哈系运算会有重复的哈希值,对于哈希值的冲突,HashMap采用链表来解决的。在HashMap里有这样的一句属性声明: transient Entry[] table; Entry就是HashMap存储数据所用的类,它拥有的属性如下 final K key; V value; final int hash; EntryK,V next; 看到next了吗?next就是为了哈希冲突而存在的。比如通过哈希运算,一个新元素应该在数组的第10个位置,但是第10个位置已经有Entry,那么好吧,将新加的元素也放到第10个位置,将第10个位置的原有Entry赋值给当前新加的 Entry的next属性。数组存储的是链表,链表是为了解决哈希冲突的,这一点要注意。 几个关键的属性 存储数据的数组 transient Entry[] table; 这个上面已经讲到了 默认容量 static final int DEFAULT_INITIAL_CAPACITY = 16; 最大容量 static final int MAXIMUM_CAPACITY = 1 30; 默认加载因子,加载因子是一个比例,当HashMap的数据大小=容量*加载因子时,HashMap会将容量扩容 static final float DEFAULT_LOAD_FACTOR = 0.75f; 当实际数据大小超过threshold时,HashMap会将容量扩容,threshold=容量*加载因子 int threshold; 加载因子 final float loadFactor; HashMap的初始过程 构造函数1 ??? public HashMap(int initialCapacity, float loadFactor) { ??????? if (initialCapacity 0) ??????????? throw new IllegalArgumentException(Illegal initial capacity: + ?????????????????????????????????????????????? initialCapacity); ??????? if (initialCapacity MAXIMUM_CAPACITY) ??????????? initialCapacity = MAXIMUM_CAPACITY; ??????? if (loadFactor = 0 || Float.isNaN(loadFactor)) ??????????? throw new IllegalArgumentException(Illegal load factor: + ?????????????????????????????????????????????? loadFactor); ??????? // Find a power of 2 = initialCapacity ??????? int capacity = 1; ??????? while (capacity initialCapacity) ??????????? capacity = 1; ?? ??????? this.loadFactor = loadFactor; ??????? threshold = (int)(capacity * loadFactor); ??????? table = new Entry[capacity]; ??????? init(); ??? } 重点注意这里 while (capacity initialCapacity) ??????????? capacity = 1; capacity才是初始容量,而不是initialCapacity,这个要特别注意,如果执行new HashMap(9,0.75);那么HashMap的初始容量是16,而不是9,想想为什么吧。 构造函数2 public HashMap(int initialCapacity) { ??????? this(initialCapacity, DEFAULT_LOAD_FACTOR); ??? } 构造函数3,全部都是默认值 ?? public HashMap() { ??????? t

您可能关注的文档

文档评论(0)

ziyouzizai + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档