java hashmap优化_Java HashMap性能优化/替代

我想创建一个大型HashMap,但put()性能不够好。有任何想法吗?

欢迎其他数据结构建议,但我需要Java Map的查找功能:

map.get(key)

就我而言,我想创建一个包含2600万个条目的地图。使用标准的Java HashMap,插入2到3百万次后,放置速度会变得异常缓慢。

另外,有人知道对密钥使用不同的哈希码分布是否有帮助?

我的哈希码方法:

byte[] a = new byte[2];

byte[] b = new byte[3];

...

public int hashCode() {

int hash = 503;

hash = hash * 5381 + (a[0] + a[1]);

hash = hash * 5381 + (b[0] + b[1] + b[2]);

return hash;

}

我正在使用adding的关联属性来确保相等的对象具有相同的哈希码。数组是字节,值的范围是0-51。在两个数组中,值只能使用一次。如果a数组包含相同的值(任一顺序)且b数组的对象相同,则对象相等。因此a

= {0,1} b = {45,12,33}和a = {1,0} b = {33,45,12}是相等的。

编辑,一些注意事项:

少数人批评使用哈希图或其他数据结构来存储2600万个条目。我不明白为什么这看起来很奇怪。在我看来,这似乎是经典的数据结构和算法问题。我有2600万个项目,我希望能够快速将其插入数据结构并从数据结构中查找它们:给我数据结构和算法。

将默认Java HashMap的初始容量设置为2600万会 降低 性能。

有人建议在其他情况下使用数据库,这绝对是明智的选择。但是我确实是在问一个数据结构和算法问题,一个完整的数据库会比一个好的数据结构解决方案矫kill过正,而且速度慢得多(毕竟,所有数据库只是软件,但可能会有通信和磁盘开销)。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值