首页 > 编程语言 >java中concurrentHashMAP和HashTable有什么区别?

java中concurrentHashMAP和HashTable有什么区别?

时间:2023-07-04 20:32:14浏览次数:49  
标签:ConcurrentHashMap java 迭代 concurrentHashMAP 线程 HashTable 哈希 null

ConcurrentHashMap和HashTable都是Java中用于实现线程安全的哈希表数据结构的类,但它们有一些关键的区别。

  1. 线程安全性:ConcurrentHashMap是通过使用锁分段技术来实现线程安全的。它将整个哈希表分成了多个段(默认为16个),每个段有自己的锁。这样,在大多数情况下,多个线程可以同时访问不同的段,从而提高并发性能。而HashTable使用一个全局的锁,因此只能有一个线程访问哈希表,这会带来较低的并发性能。
  2. Null值:ConcurrentHashMap允许null键和null值的存在,而HashTable则不允许。如果尝试将null键或null值放入HashTable中,将抛出NullPointerException异常。
  3. 迭代器支持:ConcurrentHashMap的迭代器是弱一致性的,它可以容忍在迭代过程中其他线程对Map进行修改。而HashTable的迭代器是强一致性的,如果在迭代过程中其他线程对HashTable进行修改,将抛出ConcurrentModificationException异常。
  4. 性能:一般情况下,ConcurrentHashMap的性能比HashTable更好,特别是在并发访问较高的场景下。由于ConcurrentHashMap使用了分段锁,多个线程可以同时访问不同的段,而HashTable在并发环境下需要等待全局锁的释放,导致性能下降。

总而言之,如果需要进行并发访问的高性能哈希表操作,推荐使用ConcurrentHashMap。如果对线程安全性要求不高,或者需要兼容旧的遗留代码,可以使用HashTable。

标签:ConcurrentHashMap,java,迭代,concurrentHashMAP,线程,HashTable,哈希,null
From: https://blog.51cto.com/u_16095802/6625136

相关文章

  • Java虚拟机(JVM)内存底层分析
    对象和类的详解类:我们叫做class。对象:我们叫做Object,instance(实例)。总结1.类可以看成一类对象的模板,对象可以看成该类的一个具体实例。2.类是用于描述同一类型的对象的一个抽象概念,类中定义了这一类对象所应具有的共同的属性、方法。类的定义:对于一个类来说,有三种成员:属......
  • java的vscode自动补全
    1.vscode补全打印、循环和main函数vscode支持Eclipse和IDEA两个IDE的代码补全方式具体如下表: 代码片段Eclipse风格快捷方式IDEA风格快捷方式System.out.println()sysoutsoutSystem.err.println()syserrserr当前函数签名的System.out.println()sys......
  • 一些Java编程中的基本概念
    介绍一些编程中的基本概念,比如:标识符、变量、常量、数据类型、运算符、基本数据类型的类型转换等。二进制和十进制的转化1.十进制整数转换为二进制整数采用"除2取余,逆序排列"法。2.二进制转十进制采用“权相加法”。注释在Java中根据注释的功能不同,主要分为单行注释、多行注......
  • java调用filter,map方法
    java的集合类,没有直接实现filter,map这些函数式方法,要调用这些方法,可以使用Java8的StreamAPI详细使用可参考:Java8中Stream详细用法大全 Java8的StreamAPI的坑1.没有直接的findObj方法findFirst和findAny都不支持传入条件要从list中查找一个对象,只能通过filte......
  • Java编程里的控制语句
    控制语句:把语句组合成能完成一定功能的小逻辑模块。它分为三类:顺序、选择和循环。1.“顺序结构”代表“先执行a,再执行b”的逻辑。2.“条件判断结构”代表“如果…,则…”的逻辑。3.“循环结构”代表“如果…,则重复执行…”的逻辑。条件判断结构(选择结构)条件判断结构有:if结构......
  • PAT乙级【Java题解合集】
    ✨说在前面       这个暑假博主用大概两周不到的闲暇时间把PAT乙级的110道算法题全部肝完了,个人感觉题目的难度大部分在中等偏下,大概有二十道左右的题目还是蛮有意思的,值得细细去钻研,本专栏非常适合新手入门算法,也适合Java算法老手巩固一些基本知识点,由于C站上关于PAT乙级J......
  • 简单了解java
    Java各版本的含义JavaSE(JavaStandardEdition):标准版,定位在个人计算机上的应用JavaEE(JavaEnterpriseEdition):企业版,定位在服务器端的应用JavaME(JavaMicroEdition):微型版,定位在消费性电子产品的应用上Java的特性和优势1.跨平台/可移植性:这是Java的核心优势。2.安全性3.面......
  • 常用的前端JavaScript方法封装
     1、输入一个值,返回其数据类型**functiontype(para){returnObject.prototype.toString.call(para)} 2、数组去重functionunique1(arr){return[...newSet(arr)]}functionunique2(arr){varobj={};returnarr.filter(ele=>{if......
  • 【10.0】前端基础之JavaScript进阶
    【10.0】前端基础之JavaScript进阶【一】自定义对象可以看成Python中的字典,但是在JS中的自定义对象要比Python里面的字典操作起来更方便【1】创建自定义对象方式一vard={"键":"值",};操作方法vardict={"name":"dream","age":18};vardict={"name":"dream&......
  • java http大文件断点续传上传示例
    ​ 4GB以上超大文件上传和断点续传服务器的实现随着视频网站和大数据应用的普及,特别是高清视频和4K视频应用的到来,超大文件上传已经成为了日常的基础应用需求。但是在很多情况下,平台运营方并没有大文件上传和断点续传的开发经验,往往在网上找一些简单的PHP或者Java程序来实现基......