码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 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 的分布不均匀问题影响到查询性能。
  • 相关阅读:
    YOLOv8改进AFPN:改进用于目标检测的渐近特征金字塔网络AsymptoticFPN,加强非相邻层的直接交互,YOLO系列高效涨点
    中秋节祝福程序源代码分享:土地分类数据阈值筛选和重投影分类
    QT_day6
    MySQL 主从复制原理
    Hyperledger Fabric 2.2 学习笔记:测试网络test-network
    AcWing 1211:蚂蚁感冒 ← 模拟题
    数据结构与算法 | 第二章:线性表
    解决在服务器中减少删除大文件夹耗时太久的问题
    编程奇境:C++之旅,从新手村到ACM/OI算法竞赛大门(武器:递归与递推)
    学习笔记-WinRM
  • 原文地址:https://blog.csdn.net/qq_63431773/article/details/133828410
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号