Java中的hashmap

所谓哈希表,是一种数据的存储结构,我们可以通过数据的“关键码值”来直接访问表。通过散列的方法(可以理解为一种特殊的数学过程=_=),我们可以把关键码值映射到数组中的不同位置。

设计散列系统的目标是对于任一个关键码值Key,都能通过某散列函数的计算来得到一个数组中的存储下标,使得该位置存储值Value。这样一来就很可能出现不同的关键码值对应同一个数组下标的情况,因此设计冲突解决策略也是必须的。

一种很容易想到的解决冲突的策略是,每当要存储一个关键值为Key的数据时,首先判断计算出的存储下标处是否已经存储了一个数据,如果是则将下标值进行“+1”操作,继续判断,直到判断为否时存入数据。

根据以上原理我们可以设计一个简单的程序来模拟哈希表的实现(这里假设Key和Value的数据类型都是int)

public class HashDemo {

static int size = 1000;

static int[] hash = new int[size];

int currsize = 0;

int Key, Value;

static {

for (int i = 0; i < size; i++) {

hash[i] = -1;

}

}

// 构造方法

public HashDemo(int Key, int Value) {

this.Key = Key;

this.Value = Value;

}

public HashDemo() {}

// 计算hashcode

public int hashcode(int Key) {

int index = Key % size;

if (currsize == size) {

return -1;

} else {

while (index >= 0 && index < size && hash[index] != -1) {

index++;

if (index == size - 1) {

index++;

}

}

return index;

}

}

// 往HashDemo中插入测试数据

public boolean put(int Key, int Value) {

int index = hashcode(Key);

if (index == -1 || index < 0 || index >= size)

return false;

else {

hash[index] = Value;

return true;

}

}

public void Tester() {

HashDemo hd = new HashDemo();

long starttime = System.currentTimeMillis();

for (int i = 0; i < 100000; i++) {

hd.put(i * i, i * i);

}

long endtime = System.currentTimeMillis();

System.out.println(“100000次put所用时间:” + (endtime - starttime) + “ms”);

}

}

程序测试结果:

二、java中hashmap的具体实现

import java.util.HashMap;

public class HashTest {

public void Tester(){

HashMap<Integer,Integer> hm=new HashMap<Integer,Integer>();

long starttime=System.currentTimeMillis();

for(int i=0;i<1000000;i++){

Integer n=new Integer(i);

hm.put(nn,nn );

}

long endtime=System.currentTimeMillis();

System.out.println(“100000次put所用时间:”+(endtime-starttime)+“ms”);

starttime=System.currentTimeMillis();

for(int i=0;i<1000000;i++){

Integer n=new Integer(i);

Integer m=hm.get(n*n);

}

endtime=System.currentTimeMillis();

System.out.println(“100000次get所用时间:”+(endtime-starttime)+“ms”);

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
5%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!**

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值