码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • HashTable、HashMap、ConcurrentHashMap之间的区别


    文章目录

    • 一、HashMap和HashTable、ConcurrentHashMap之间的区别
    • 二、HashTable和ConcurrentHashMap之间的区别
      • 2.1HashTable能保证线程安全的原因
      • 2.2HashTable存在的问题
      • 2.3ConcurrentHashMap针对HashTable的问题做出了优化

    一、HashMap和HashTable、ConcurrentHashMap之间的区别

    HashMap线程不安全,HashTable和ConcurrentHashMap线程安全。

    二、HashTable和ConcurrentHashMap之间的区别

    2.1HashTable能保证线程安全的原因

    Hashtable能保证线程安全,是因为在Hashtable里的关键方法里套上了synchronized(相当于给this加锁)。

    2.2HashTable存在的问题

    只要两个线程操作同一个Hashtable就会出现锁冲突,但实际上对于哈希表来说这样相当于加了一些不必要的锁,因为有些情况是不涉及到线程安全问题的。
    比如一个线程操作哈希表1号链表中的元素,另一个线程操作哈希表2号链表中的元素,在不考虑扩容的前提下,这种对哈希表的操作是不会发生线程安全问题的。如果两个线程操作哈希表的同一个链表才有可能出现线程安全问题。

    2.3ConcurrentHashMap针对HashTable的问题做出了优化

    ①相比于Hashtable,ConcurrentHashMap最核心的改进是把Hashtable里关键方法里的大锁改进成了哈希表中每个链表独立的小锁(ConcurrentHashMap把每个链表的头节点作为锁对象),这样大幅度降低了锁冲突的概率。
    ②充分利用CAS特性,省去了一些不必要加锁的环节。比如需要使用变量记录哈希表中元素的个数,此时就可以使用原子操作(CAS)修改变量的值。
    ③ConcurrentHashMap针对读操作没有加锁。读和读之间、读和写之间不会有锁竞争,写和写之间有锁竞争。那这样ConcurrentHashMap会不会出现“读到一个修改了一半的数值”呢?答案是不会的,因为ConcurrentHashMap在底层编码的时候会比较谨慎地处理一些细节,比如修改的时候会避免使用++、–这种非原子的操作,会使用=(赋值)这种原子性的操作,这样读的时候要么读到的是写之前的旧值要么读到的是写之后的新值。
    ④ConcurrentHashMap针对扩容操作做出了单独的优化。哈希表在扩容的时候会把所有的元素都拷贝一遍,如果元素比较多拷贝就会比较耗时。ConcurrentHashMap在扩容时会把数据分成多次来拷贝,每次只拷贝一部分数据(化整为零)。

  • 相关阅读:
    论文作图之高压缩比导出PDF
    JAVA_WEB项目之j使用query的验证框架的例子
    【无标题】
    如何把PDF文档转换成Word格式呢?
    Java Thread类详解
    隐式意图和Activity启动模式:实现文件打开应用【Android、隐式意图】
    Nmap 诸神之眼深度解析
    【服务器数据恢复】Linux服务器EXT4文件系统故障的数据恢复案例
    ATF源码篇(九):docs文件夹-Components组件(8)固件升级
    直流有刷电机驱动基于STM32F302R8+X-NUCLEO-IHM07M1(三)
  • 原文地址:https://blog.csdn.net/zhanlongsiqu/article/details/133090876
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号