关闭

hashMap使用中的性能提高

1570人阅读 评论(0) 收藏 举报
当你要创建一个比较大的hashMap时,充分利用另一个构造函数
public HashMap(int initialCapacity, float loadFactor)
initialCapacity:初始容量loadFactor:加载因子容量 是哈希表中桶的数量,初始容量只是哈希表在创建时的容量。加载因子 是哈希表在其容量自动增加之前可以达到多满的一种尺度。当哈希表中的条目数超出了加载因子与当前容量的乘积时,通过调用 rehash 方法将容量翻倍。 
应该避免HashMap多次进行了hash重构,扩容是一件很耗费性能的事,在默认中initialCapacity只有16,而loadFactor是 0.75,需要多大的容量,你最好能准确的估计你所需要的最佳大小,同样的Hashtable,Vectors也是一样的道理。

如果我们的对HashMap的容量需求不是很大,你给它一个默认1W的容量,显然又浪费宝贵的空间了。至于这两个参数的选择可以自己去把握,甚至可以设定动态绑定:分析历史数据,找出规律,或者预测未来的走向找出规律。对HashMap这两个参数实现一个动态的调整。比如早上8点~9点A业务比较忙,它对应的HashMap可以提前多给些空间,而10点以后B业务使用的HashMap比较忙,A相对清闲,可以缩减A的空间给B。

如果从数据库的表中读取记录存入HashMap中,完全可以根据记录的行数(row size)来初始化HashMap的容量,这样就可以达到reHash的最少次数,同时也保证了HashMap所需的最小容量:

比如:通过SQL语句: select count(字段) as rowSize from 表

提到行数: rowSize = 30

那么我们在定义HashMap的时候:  HashMap<String,String> h = new HashMap<String,String>(rowSize,1f);


0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

HashMap详解及性能提升

本来想自己写,却发现一篇写的很好的文章,特此jiej
  • hijiankang
  • hijiankang
  • 2014-10-16 19:00
  • 1808

影响hashMap性能的因素

首 先算得key得hashcode值,然后跟数组的长度-1做一次“与”运算(&)。看上去很简单,其实比较有玄机。比如数组的长度是2的4次方, 那么hashcode就会和2的4次方-1做“与”运算。很多...
  • cnq2328
  • cnq2328
  • 2017-03-07 23:12
  • 523

HasHashMap会出现性能问题的情况

下面是API文档中的解释 基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了不同步和允许使用 null 之外,HashMap 类与 Ha...
  • weijinqian0
  • weijinqian0
  • 2016-08-01 11:19
  • 586

HashMap 4种循环遍历方式及其性能对比

主要介绍HashMap的四种循环遍历方式,各种方式的性能测试对比,根据HashMap的源码实现分析性能结果,总结结论。 1. Map的四种遍历方式 下面只是简单介绍各种遍历示例(以HashMap...
  • system1190
  • system1190
  • 2015-10-11 10:42
  • 854

Android应用性能优化之使用SparseArray替代HashMap

Android SparseArray代替HashMap提升性能
  • hlglinglong
  • hlglinglong
  • 2015-05-03 23:26
  • 2453

SparseArray替代HashMap来提高性能

SparseArray是 Android框架独有的类,在标准的JDK中不存在这个类。它要比 HashMap 节省内存,某些情况下比HashMap性能更好,按照官方问答的解释,主要是因为SparseAr...
  • yan8024
  • yan8024
  • 2015-09-04 23:01
  • 503

HashMap与ConcurrentHashMap的内存占用与get操作性能比较

一、测试背景         项目中需要提供一个单机计算视频相似度的服务,计算的方式是对视频标题进行分词,提取关键词,然后通过word2vec的方式对关键词进行embedding,最后通过向量累加得到...
  • ytbigdata
  • ytbigdata
  • 2016-07-08 17:08
  • 3832

SparseArray替代HashMap来提高性能

SparseArray是Android框架独有的类,在标准的JDK中不存在这个类。它要比 HashMap 节省内存,某些情况下比HashMap性能更好,按照官方问答的解释,主要是因为SparseA...
  • opzoonzhuzhengke
  • opzoonzhuzhengke
  • 2014-03-27 14:47
  • 501

SparseArray替代HashMap来提高性能

SparseArray是 Android框架独有的类,在标准的JDK中不存在这个类。它要比 HashMap 节省内存,某些情况下比HashMap性能更好,按照官方问答的解释,主要是因为SparseAr...
  • pengjin1985
  • pengjin1985
  • 2014-11-27 10:57
  • 322

SparseArray替代HashMap来提高性能

SparseArray是 Android框架独有的类,在标准的JDK中不存在这个类。它要比 HashMap 节省内存,某些情况下比HashMap性能更好,按照官方问答的解释,主要是因为SparseAr...
  • u014628886
  • u014628886
  • 2017-04-14 19:12
  • 126
    个人资料
    • 访问:23054次
    • 积分:771
    • 等级:
    • 排名:千里之外
    • 原创:44篇
    • 转载:22篇
    • 译文:0篇
    • 评论:13条
    友情链接
    新浪微博
    最新评论