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的位置

数组扩容

详细描述

相关推荐
2501_92495269几秒前
C++中的适配器模式
开发语言·c++·算法
堕2743 分钟前
JavaEE初阶——《计算机是如何工作的》
java·java-ee
良木生香5 分钟前
【C++初阶】:C++类和对象(中):类的默认成员函数---万字解说(最主要的四点)
c语言·开发语言·c++
☆5667 分钟前
C++安全编程指南
开发语言·c++·算法
无心水9 分钟前
【时间利器】4、JavaScript时间处理全解:Date/moment/dayjs/Temporal
开发语言·前端·javascript·状态模式·openclaw·date/moment·dayjs/temporal
0xDevNull11 分钟前
Apache RocketMQ 完全指南
java·rocketmq
星轨初途12 分钟前
类和对象(中):六大默认成员函数与运算符重载全解析
开发语言·c++·经验分享·笔记·ajax·servlet
骇客野人13 分钟前
用python实现一个查询当天天气的MCP服务器
服务器·开发语言·python
XiaoLeisj15 分钟前
Android 文件存储实战:从应用私有目录读写到网络文件落盘与公共存储接入
android·java·网络·文件操作
天空属于哈夫克317 分钟前
拒绝被动响应:企业微信主动调用接口高阶方案
开发语言·python