hashtable 简单介绍
Hashtable
1 注意小写 table
2 常用方法
void clear()
boolean contains(Object value) //作用等于containsValue(Object value)
//在HashMap中已经不存在
boolean containsKey(Object key)
boolean containsValue(Object value)
Set<Entry<K, V>> entrySet()
boolean equals(Object object)
V get(Object key)
int hashCode() //返回此map的哈希值
boolean isEmpty()
Set<K> keySet()
V put(K key, V value)
V remove(Object key)
其中hashcode是重写的方法这里给出Java® Platform, Standard Edition & Java Development Kit Version 12 API Specification关于abstractmap的hashcode方法的解释
详见
https://docs.oracle.com/en/java/javase/12/docs/api/java.base/java/util/AbstractMap.html#hashCode()
返回这个map的hash码的值
map的hash码 定义为
这个map的entrySet()的每一个键值对的hash码的和
这确保了对于map m1以及m2 m1.equals(m2) 即为
m1.hashCode()==m2.hashCode()
正如Object.hashCode()的常规协定
简单来说就是返回这个map的地址 因为对于每一个map m1 m2这个值都是相同的,那这
个就可以作为类的地址,
可以看出 返回值就是entryset的和
简单介绍hash (散列)
hash 是一种压缩映射
把任意长度的输入 通过算法变成固定长度的输出 输出值即为hash值 算法即为某种hash算法
散列值的空间远小于输入空间 但是不同的输入可能会产生相同的输出 即碰撞 hash算法需要对碰撞进行处理
简单介绍 常用hash算法
1直接寻址法
取关键字的线性函数生成散列地址H(key)=a *key+b;
2
数字分析法 分析数据,找出数字规律,尽可能利用数据构造重估纪律较低的散列地址,例如员工生日,年月冲突较大,而月日冲突的情况明显减少
3平方取中法
关键字平方后取其中几位 作为散列地址
4
折叠法 将关键字分割成位数相同的几部分,各部分相加,作为散列地址
5
随机数法 取关键字作为随机数种子生成随机数作为散列地址
6
除数留余 H(key)=key%p p一般取素数或者奇数 减少碰撞
简单介绍 处理冲突的方法
1
开放寻址法 Hi=(H(key) + di) MOD m i=1,2,3,… d[i]是数列
就是第i次产生碰撞探测增量序列,有常见三种取法
1
di=1,2,3,4,… 很容易理解 一个地址被占用继续使用下一个地址 称为线性探测再散列
2
di=1^2,-1^2,2^2,-2^2,…+-k^2 只是另一种产生新地址的方法 成为二次探测再散列
3
di=伪随机数序列 称为随即探测再散列
2
再散列法 Hi=RHi(key),i=1,2,… 不同的散列函数,其中RHi为产生碰撞,使用另一个散列函数重新计算
3
链地址法 就是每一次产生碰撞,使用同一个散列地址,让碰撞输入指向前一个输入
4
建立公共溢出区 每一次产生碰撞 就是用溢出区的地址
回到这个问题
计算机存储数据的地址很长很复杂,通过hash算法,得到hash地址,根据这个例子我们map中的元素较少,hashcode也会比较小,但是元素不同,hashcode不同,而返回值也确实与具体的map有关,所以在api中的介绍,并没有用对象的地址作为定义,而是用了每一个键值对的hash码的和,这样的说法,因为并不是创建map时产生的hashcode,而是每次增减删改元素时,其hashcode都会变化
这里只介绍java语言的语法中关于hashcode()方法的简单体感,以及背后的数学模型,逻辑实现,并不打算继续深入介绍底层实现,有兴趣可以去学习微机原理,计算机硬件的物理实现,等相关课程。
3 HashMap和Hashtable几乎等价 区别在于
0
作者不同
Hashtable Arthur van Hoff Josh Bloch Neal
Gafter
HashMap 多了Doug Lea 道格·利 JSR-166是来自于Doug编写的util.concurrent包。jsr 即Java Specification Requests(java语法标准)著有Concurrent Programming in Java:
Design Principles and Patterns
Arthur van Hoff 最早任职于Sun
Microsystems公司,从事java程序语言的早期开发工作,设计并实现jdk1.0的许多方面,java编译器,java调试器,许多java类以及hotjava浏览器
Neal Gafter是Java SE 4和5的主要设计者,参与了78,曾是c++标准委员会的一员,领导开发c++编译器
Josh Bloch 为领导了众多Java平台特性的设计和实现,其中包括Java Collection框架、java.math包以及assert机制。著有 Effective Java 一书。
产生时间
Hashtable是java一开始发布就提供的键值映射的数据结构
HashMap产生于JDK1.2,已经成为应用广泛的一种数据类型
1
HashMap中,null可以作为键,这样的键只有一个;可以有一个或多个键所对应的值为null;而Hashtable则不行
2
HashMap是非synchronized,而Hashtable是synchronized,这意味着Hashtable是线程安全的,在单线程环境下它比HashMap要慢。而java5以上需要线程安全时,可以使用ConcurrentHashMap
3
遍历方式的内部实现上不同
4
初始容量大小和每次扩充容量大小的不同
Hashtable默认的初始大小为11,之后每次扩充,容量变为原来的2n+1。HashMap默认的初始化大小为16。之后每次扩充,容量变为原来的2倍。Hashtable和HashMap设计时的侧重点不同。Hashtable的侧重点是哈希的结果更加均匀,使得哈希冲突减少。而HashMap则更加关注hash的计算效率问题。
5 计算元素的位置的方法不同
hashtable是利用对象的hashcode用除留余
hashmap则是进行位运算
hashtable 简单介绍的更多相关文章
- Java 集合系列11之 Hashtable详细介绍(源码解析)和使用示例
概要 前一章,我们学习了HashMap.这一章,我们对Hashtable进行学习.我们先对Hashtable有个整体认识,然后再学习它的源码,最后再通过实例来学会使用Hashtable.第1部分 Ha ...
- Java 集合系列 10 Hashtable详细介绍(源码解析)和使用示例
java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...
- Appium Android Bootstrap源代码分析之简单介绍
在上一个系列中我们分析了UiAutomator的核心源代码,对UiAutomator是怎么执行的原理有了根本的了解.今天我们会開始另外一个在安卓平台上基于UiAutomator的新起之秀--Appiu ...
- 【转】Java 集合系列11之 Hashtable详细介绍(源码解析)和使用示例
概要 前一章,我们学习了HashMap.这一章,我们对Hashtable进行学习.我们先对Hashtable有个整体认识,然后再学习它的源码,最后再通过实例来学会使用Hashtable.第1部分 Ha ...
- [原创]关于mybatis中一级缓存和二级缓存的简单介绍
关于mybatis中一级缓存和二级缓存的简单介绍 mybatis的一级缓存: MyBatis会在表示会话的SqlSession对象中建立一个简单的缓存,将每次查询到的结果结果缓存起来,当下次查询的时候 ...
- 利用Python进行数据分析(7) pandas基础: Series和DataFrame的简单介绍
一.pandas 是什么 pandas 是基于 NumPy 的一个 Python 数据分析包,主要目的是为了数据分析.它提供了大量高级的数据结构和对数据处理的方法. pandas 有两个主要的数据结构 ...
- 利用Python进行数据分析(4) NumPy基础: ndarray简单介绍
一.NumPy 是什么 NumPy 是 Python 科学计算的基础包,它专为进行严格的数字处理而产生.在之前的随笔里已有更加详细的介绍,这里不再赘述. 利用 Python 进行数据分析(一)简单介绍 ...
- yii2的权限管理系统RBAC简单介绍
这里有几个概念 权限: 指用户是否可以执行哪些操作,如:编辑.发布.查看回帖 角色 比如:VIP用户组, 高级会员组,中级会员组,初级会员组 VIP用户组:发帖.回帖.删帖.浏览权限 高级会员组:发帖 ...
- angular1.x的简单介绍(二)
首先还是要强调一下DI,DI(Denpendency Injection)伸手获得,主要解决模块间的耦合关系.那么模块是又什么组成的呢?在我看来,模块的最小单位是类,多个类的组合就是模块.关于在根模块 ...
随机推荐
- keil4编译Error: User Command terminated, Exit-Code = 1解决
编译出错结果如下图: 通过分析可看出,错误原因是:调用fromelf.exe指令的路径不对.Keil中设置的是 E:\Keil\ARM\BIN40\fromelf.exe(安装Keil位置不同,此处显 ...
- RFID和QRCODE对比
1.技术介绍 1.1 RFID 射频识别,RFID(Radio Frequency Identification)技术,又称无线射频识别,是一种通信技术,可通过无线电讯号识别特定目标并读写相关数据,而 ...
- lombok的安装
Lombok简介 Lombok是一个可以通过简单的注解形式来帮助我们简化消除一些必须有但显得很臃肿的Java代码的工具,通过使用对应的注解,可以在编译源码的时候生成对应的方法.官方地址:https:/ ...
- mysql建数据库的字符集与排序规则
1.字符集说明: 一般选择utf8.下面介绍一下utf8与utfmb4的区别. utf8mb4兼容utf8,且比utf8能表示更多的字符.至于什么时候用,看你的做什么项目了,到http://blog. ...
- Arduino入门笔记(5):1602液晶实验(实现时钟)
转载请注明:@小五义 http://www.cnblogs.com/xiaowuyi 欢迎加入讨论群 64770604 一.本次实验所需器材 1.Arduino板 https://item.taoba ...
- Mysql8 安装过程及安装过程系列问题记录
前言: 今天,想装个高版本一点的mysql试试,于是下载了一个mysql8的zip版本. 地址:https://dev.mysql.com/downloads/file/?id=484900 没想到安 ...
- 超好用的C#控制台应用模板
本文是Wei的公众号投稿文章: 默认模板之缺 在工作学习中,我们经常需要创建一些简单的控制台应用(Console App)去验证某个想法,或者作为小工具交付给其他同事. 通常我们的选择是 Visual ...
- JavaSSM框架报HTTP Status 500 - Servlet.init() for servlet springMvc threw exception错误
如下,刚搭建的项目报这样的错,刚学框架的我一脸懵逼...网上很多说是jdk或者springmvc的的jar的版本问题,但是我其他项目都可以啊,所以排除了这个问题. 经过几个小时的排查,发现了我的问题所 ...
- win10启动远程桌面连接的设置
现在win10系统用的非常普遍,做项目的时候,也经常将一台win10系统的机器当作服务器使用.这就涉及到利用远程桌面登录到win10系统的问题,有几次利用远程桌面登录win10系统的设置经历,好像每次 ...
- [intellij IDEA]导入eclipse项目
1.因为最近eclipse在更新代码时经常卡死,就想将eclipse的项目迁移到idea.特意写下自己的经验,给迁移时遇到困难的朋友一些帮助 File -> new ->project f ...