问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

java中实现一个简单HashMap(就是自己写一个简单的,不要太复杂);

发布网友 发布时间:2022-04-06 01:50

我来回答

3个回答

热心网友 时间:2022-04-06 03:19

Hashmap这个结构,是从一个key到一个value的映射的集合,其中的hash是指用hash数组(也就是散列表)来存放value集合。
实现思路上,通过key的hashcode来确定value存储的位置,遇到冲突的位置就通过某个规则找下一个位置。
实现的简述:
1. value数组,Object[] values;
2. key,Object key,可能要考虑hashcode方法和equals方法的重写;
3. 冲突解决规则,下一个位置=(该位置*2+123)% values.size();
需要注意的是,values存的元素不是一个value而已,还要保留用来确定位置的hashcode值,因为在冲突的时候,Hashmap的get(key)方法需要比较hashcode来确定是不是key对应的value。

更好的办法,是values存一个链表,冲突的元素都放在链表里,在get(key)的时候遍历这个链表来获得value。再细节的东西,自己想想吧,这个写起来也不算复杂,可以动手试试。追问有没有代码 急需 想看看 只是理论的我一些 但代码怎么编写就不知道了 谢谢

追答试着写写吧,遇到问题了再问吧。看现成的,会忽视掉很多细节的问题。别怕复杂,什么复杂的问题都是一个个小问题组成的,慢慢来。我也是真没空敲这些了。实在想看,百度里搜搜吧,也许会有,或者像某楼说的,看看jdk源码的实现。

热心网友 时间:2022-04-06 04:37

我觉得JDK里面那个HashMap已经很简单了。
你看着那么多行代码,其实很多都是注释。
顶多把table扩容的功能去掉。

热心网友 时间:2022-04-06 06:12

HashMap<String,String> map=new HashMap<String,String>();//定义

map.put("key","我要最佳答案");//给map插值

String str=map.get("key");//从map中取值
Ssytem.out.println(str)
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
海关老师:你好. 如果是加工贸易手册报关的话,报关单价要与手册备案的... 上海危险品报关公司哪家好 长辈可以为老不尊出口成脏晚辈们却连句重话也不能对长辈说试问这样的长... 老一辈为什么这么喜欢拿态度说事? 系统集成项目管理工程师(一):信息化知识 "压哨"的英语怎么拼啊 周山打鱼的年薪多少钱 望穿秋水(打一动物)谜底及原因 想买一本词典 古代汉语字典买哪一种版本比较好? php的数组java如何实现? PHP的算法可以实现大数据分析吗 如何实现一个hashmap c++ 如何设计线程安全的 HashMap hashmap 中 hash 函数怎么是是实现的?还有哪些 hash 的实现方式 HashMap的内部实现机制,Hash是怎样实现的,什么时候ReHash hashmap底层是怎么实现的 如何实现线程安全的HashMap 用java,怎么把php数组转换成HashMap或者集合 hashmap有哪些关键技术,是怎么实现的 HashMap内部是如何实现的? in_array 和in 有什么区别呢?in_array 是php的函数吗,in是在mysql中的吗,我不太清楚,哪位高人指点一下 在thinkphp中的&lt;if&gt;condition条件中可以用IN 么? php数组函数in_array() 查找数组值是否存在拜托各位了 3Q php用in_arra数组查询的问题 2个自定义的PHP in_array 函数,解决大量数据判断in_array的效率问题 php in_array的问题 php file函数和in_array函数问题 php 常用的数组函数都有哪些? 作用是什么?有什么特点? 怎么使用? CKFinder(php版)上传图片报错,总是显示500的错误,请问该怎么解决这个问题呢? php怎么打开socket扩展? 如何在linux上添加PHP的socket扩展 php怎么创建开启socket服务 PHP如何开启socket win 7phpstudy 怎样打开socket支持 PHP SOCKET 技术研究 php是如何加载扩展的? 如何用PHP实现Socket服务器 什么是socket?PHP如何实现socket通信 php怎么打开socket扩展 php和js区别是什么 PHP与JS之间的区别? php与js哪个更难?两者有何不同? PHP框架和JS框架是同一个概念的东西吗? js中的函数和php中的函数一样吗? js和php 在数组处理上的不同 PHP和JS在循环,条件判断中的不同之处 PHP如何找回密码 zblogPHP后台登录密码忘记了怎么办 如何重置找回phpcms管理员密码