Java基础面试-HashMap和HashTable

HashMap和HashTable的区别?

  • HashMap方法没有synchronized修饰,线程非安全,HashTable线程安全
  • HashMap允许key和value为null,而HashTable不允许

底层实现

数组+链表

jdk8开始链表高度到8、数组长度超过64,链表转变为红黑树,元素以内部类Node节点存在

  • 计算key的hash值,二次hash然后对数组长度取模,对应到数组下标,
  • 如果没有产生hash冲突(下标位置没有元素),则直接创建Node存入数组
  • 如果产生hash冲突,先进行equal比较,相同则取代该元素,不同,则判断链表高度插入链表,链表高度达到8,并且数组长度到64则转变为红黑树,长度低于6则将红黑树转回链表
  • key为null,存在下标0的位置

数组扩容

详细描述

相关推荐
FL162386312943 分钟前
[C#][winform]基于yolov8的水表读数检测与识别系统C#源码+onnx模型+评估指标曲线+精美GUI界面
开发语言·yolo·c#
cnxy1883 小时前
围棋对弈Python程序开发完整指南:步骤1 - 棋盘基础框架搭建
开发语言·python
Nonoas4 小时前
动态代理:发布订阅的高级玩法
java·ide·intellij-idea
程序员-周李斌5 小时前
Java 死锁
java·开发语言·后端
liang_jy5 小时前
Android 事件分发机制(二)—— 点击事件透传
android·面试·源码
皮皮林5515 小时前
Prometheus+Grafana,打造强大的监控与可视化平台
java
JasmineWr5 小时前
CompletableFuture相关问题
java·开发语言
零雲6 小时前
java面试:知道java的反射机制吗
java·开发语言·面试
Jeremy爱编码6 小时前
实现 Trie (前缀树)
开发语言·c#
laocooon5238578866 小时前
插入法排序 python
开发语言·python·算法