HashMap 与 HashTable 区别

HashMap

  • HashMap是一个基于 hash 表实现的 K-V 结构的集合。

  • HashMap 是 JDK1.2 引入的一个线程不安全的集合类。

  • HashMap 内部是采用了数组加链表实现,在 JDK1.8 版本里面做了优化,引入了红黑树。当链表长度大于等于 8 并且数组长度大于 64 的时候,就会把链表转化为红黑树,提升数据查找性能。

HashTable

  • Hashtable是一个基于 hash 表实现的 K-V 结构的集合。

  • Hashtable 是 JDK1.0 引入的一个线程安全的集合类,因为所有数据访问的方法都加了一个 Synchronized 同步锁。

  • Hashtable 内部采用数组加链表来实现,链表用来解决 hash 冲突的问题。

HashMap 与 HashTable 区别

从功能特性的角度来说:

  • HashTable 是线程安全的,而 HashMap 不是。

  • HashMap 的性能要比 HashTable 更好,因为,HashTable 采用了全局同步锁来保证安全性,对性能影响较大

从内部实现的角度来说:

  • HashTable 使用数组加链表、HashMap 采用了数组+链表+红黑树
  • HashMap 初始容量是 16、HashTable 初始容量是 11
  • HashMap 可以使用 null 作为 key,HashMap 会把 null 转化为 0 进行存储, 而 Hashtable 不允许。

最后,他们两个的 key 的散列算法不同,HashTable 直接是使用 key 的 hashcode 对数组长度做取模。而 HashMap 对 key 的 hashcode 做了二次散列,从而避免 key 的分布不均匀问题影响到查询性能。

相关推荐
隔壁小邓2 分钟前
Spring-全面讲解
java·后端·spring
t1987512813 分钟前
基于多尺度特征融合与自适应权重优化的水下图像对比度与边缘增强MATLAB方法
开发语言·matlab
JustMove0n13 分钟前
互联网大厂Java面试全流程问答及技术详解
java·jvm·redis·mybatis·dubbo·springboot·多线程
SimonKing22 分钟前
5分钟学会!把代码从本地推送到 GitHub,就是这么简单
java·后端·程序员
玹外之音22 分钟前
Spring AI 11 种文档切割策略全解析
java·spring·ai编程
Java练习两年半40 分钟前
互联网大厂 Java 求职面试:技术栈与微服务深度解析
java·微服务·面试·技术栈
Seven971 小时前
类字节码:揭开Java虚拟机运行机制的神秘面纱
java
chilavert3181 小时前
程序员面试经典问题解答:java篇-2
开发语言·python
senijusene1 小时前
TCP并发服务器:poll和epoll的多路复用
开发语言·php
浅碎时光8071 小时前
Qt (按钮/显示/输入/容器类控件 布局管理器)
开发语言·qt