全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

HashMap和Hashtable的区别和实现原理

发布时间:2022-08-01 17:05:39
发布人:qyf

  HashMap 和 Hashtable 有什么区别?

  HashMap是线程不安全的,HashTable是线程安全的;

  HashMap中允许键和值为null,HashTable不允许;

  HashMap的默认容器是16,为2倍扩容,HashTable默认是11,为2倍+1扩容;

  HashMap的实现原理?

  1. 简介

  HashMap基于map接口,元素以键值对方式存储,允许有null值,HashMap是线程不安全的。

  2. 基本属性

  初始化大小,默认16,2倍扩容;

  负载因子0.75;

  初始化的默认数组;

  size;

  threshold,判断是否需要调整hashmap容量。

  3. HashMap的存储结构

  JDK1.7中采用数组+链表的存储形式。

  HashMap采取Entry数组来存储key-value,每一个键值对组成了一个Entry实体,Entry类时机上是一个单向的链表结构,它具有next指针,指向下一个Entry实体,以此来解决Hash冲突的问题。

  HashMap实现一个内部类Entry,重要的属性有hash、key、value、next。

QQ截图20220801115748

  JDK1.8中采用数组+链表+红黑树的存储形式。当链表长度超过阈值(8)时,将链表转换为红黑树。在性能上进一步得到提升。

QQ截图20220801115804

  更多关于“Java培训”的问题,欢迎咨询千锋教育在线名师。千锋已有十余年的培训经验,课程大纲更科学更专业,有针对零基础的就业班,有针对想提升技术的好程序员班,高品质课程助力你实现java程序员梦想。

相关文章

OKR与自驱力的关系是什么?

OKR与自驱力的关系是什么?

2023-10-14
office是什么软件类型?

office是什么软件类型?

2023-10-14
Cloud-IDE 是什么?

Cloud-IDE 是什么?

2023-10-14
主机和端系统之间有什么不同?

主机和端系统之间有什么不同?

2023-10-14

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取