`

ConcurrentMap和HashMap的区别

    博客分类:
  • java
 
阅读更多

类 HASHSET<E>

所有已实现的接口:Serializable, Cloneable, Iterable<E>, Collection<E>, Set<E>


此类实现 Set 接口,由哈希表(实际上是一个 HashMap 实例)支持。它不保证 set 的迭代顺序;特别是它不保证该顺序恒久不变。此类允许使用 null 元素。

此类为基本操作提供了稳定性能,这些基本操作包括 add、remove、contains 和 size,假定哈希函数将这些元素正确地分布在桶中。对此 set 进行迭代所需的时间与 HashSet 实例的大小(元素的数量)和底层 HashMap 实例(桶的数量)的“容量”的和成比例。因此,如果迭代性能很重要,则不要将初始容量设置得太高(或将加载因子设置得太低)。

注意,此实现不是同步的。如果多个线程同时访问一个哈希 set,而其中至少一个线程修改了该 set,那么它必须 保持外部同步。这通常是通过对自然封装该 set 的对象执行同步操作来完成的。如果不存在这样的对象,则应该使用 Collections.synchronizedSet 方法来“包装” set。最好在创建时完成这一操作,以防止对该 set 进行意外的不同步访问:

   Set s = Collections.synchronizedSet(new HashSet(...));


类 HASHMAP<K,V>

所有已实现的接口:Serializable, Cloneable, Map<K,V>

基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同。)此类不保证映射的顺序,特别是它不保证该顺序恒久不变。




类 CONCURRENTHASHMAP<K,V>

所有已实现的接口:

Serializable, ConcurrentMap<K,V>, Map<K,V>



支持获取的完全并发和更新的所期望可调整并发的哈希表。此类遵守与 Hashtable 相同的功能规范,并且包括对应于 Hashtable 的每个方法的方法版本。不过,尽管所有操作都是线程安全的,但获取操作不 必锁定,并且不 支持以某种防止所有访问的方式锁定整个表。此类可以通过程序完全与 Hashtable 进行互操作,这取决于其线程安全,而与其同步细节无关。



此类与 Hashtable 相似,但与 HashMap 不同,它不 允许将 null 用作键或值。

分享到:
评论

相关推荐

    Java-concurrentMap-内存模型深入分析-HotCode

    JMM规定了内存的可见性、原子性和有序性,这对于理解`concurrentMap`的工作机制至关重要。例如,`ConcurrentHashMap`使用了分段锁策略,每个段都是一个独立的`HashMap`,通过并发控制减少锁的粒度,提高并发性能。...

    Java里多个Map的性能比较(TreeMap、HashMap、ConcurrentSkipListMap)

    在Java编程中,Map接口是用于存储键值对的数据结构,而Java提供了多种Map的实现,包括TreeMap、HashMap和ConcurrentSkipListMap。本文主要比较了这三种Map的性能,尤其是在插入和查找操作上的效率。 1. **TreeMap**...

    高级程序员必会的HashMap的线程安全问题,适用于0~2年的.7z

    1. **使用线程安全的类**:Java提供了一些线程安全的Map实现,如`java.util.concurrent.ConcurrentHashMap`。ConcurrentHashMap使用分段锁技术,使得在保证线程安全的同时,提供了较好的并发性能。 2. **同步访问**...

    java阿里巴巴常用面试题

    5. **ConcurrentMap与HashMap的区别** - **ConcurrentMap** 是Java并发编程库`java.util.concurrent`中的接口,提供了线程安全的哈希映射操作。相比于HashMap,它提供了更高的并发性能,如`ConcurrentHashMap`就是...

    Java魔法解密:揭秘HashMap底层机制.pptx.pptx

    为了解决这一问题,开发者可以使用`Collections.synchronizedMap()`方法对HashMap进行包装,或者直接使用线程安全的`java.util.concurrent.ConcurrentHashMap`类。 **HashMap的性能优化** HashMap的性能优化主要...

    lmn-concurrent-hashmap:用于并行模型检查的高性能并发哈希表 C 库

    lmn-concurrent-hashmap 用于并行模型检查的高性能并发哈希映射的 C/C++ 库 要求 autoconf 2.69 automake 1.11.3 gcc 4.6.3 g++ 4.6.3 如何构建 $ autoreconf -i $ ./configure $ make 内容 细粒度锁 ChainHash ...

    java面试题

    4. **ConcurrentMap和HashMap的区别**: - `ConcurrentMap`是线程安全的Map接口,提供高效并发操作,例如`ConcurrentHashMap`。 - `HashMap`不是线程安全的,多线程环境下需手动同步。 5. **Tomcat、Apache、...

    一文让你彻底理解JavaHashMap和ConcurrentHashMap

    众所周知HashMap底层是基于数组+链表组成的,不过在jdk1.7和1.8中具体实现稍有不同。1.7中的数据结构图:先来看看1.7中的实现。这是HashMap中比较核心的几个成员变量;看看分别是什么意思?初始化桶大小,因为底层是...

    TBB 开源库及并发 Hashmap 的使用

    TBB 并发容器是 TBB 中的一个重要组成部分,提供了一些支持多线程并发访问的容器,如 concurrent_vector、concurrent_bound_queue、concurrent_priority_queue、concurrent_hash_map、concurrent_unordered_map 等。...

    hashmap-thread-test:测试 Java HashMap 是否是线程安全的

    1. **Collections.synchronizedMap()**:可以使用`Collections.synchronizedMap()`静态方法将`HashMap`包装成线程安全的`SynchronizedMap`。但请注意,尽管这个方法可以确保并发修改的安全,但仍然无法避免迭代时的...

    Map集合的继承关系图.pdf

    3. ConcurrentMap:这个接口的实现提供了针对并发访问和更新操作的原子操作,通常用在多线程环境中。 4. Map.Entry:Map内部的一个私有静态接口,用于表示键值对。 在Map接口的实现类中,有几个最为常用的实现: 1...

    java 集合详细讲解

    此外,还有其他接口如SortedSet、SortedMap和ConcurrentMap,它们分别提供了排序功能和线程安全的集合操作。SortedSet和SortedMap如TreeSet和TreeMap,它们的元素或键值对是有序的。ConcurrentMap接口则在多线程环境...

    JAVA并发容器代码随读1

    - ConcurrentMap 是 Map 接口的一个并发版本,例如 ConcurrentHashMap,它提供了高并发下的高效读写操作,而不需要像普通 HashMap 那样使用全局锁。 - ConcurrentSkipListSet 基于跳表(Skip List)实现,提供高效的...

    Java中遍历ConcurrentHashMap的四种方式详解

    ConcurrentHashMap是Java中一种高效且线程安全的HashMap实现,它提供了高效的读写操作和良好的扩展性。然而,在遍历ConcurrentHashMap时,需要注意一些关键点,否则可能会出现一些意外的结果。 方式一:使用for-...

    Java理论与实践:构建一个更好的HashMap

    《Java理论与实践:构建一个更好的HashMap》这篇文章深入剖析了Doug Lea的`util.concurrent`包中的`ConcurrentHashMap`实现,旨在展示如何在保证线程安全的同时提高并发性能。`ConcurrentHashMap`相较于传统的`...

    ConcurrentHashMap集合源码学习笔记

    ConcurrentHashMap继承了AbstractMap,实现了ConcurrentMap,Serializable接口,ConcurrentMap又实现了Map接口。ConcurrentHashMap是基于散列表实现的,存储的是Key/Value对,底层使用数组+链表+红黑树+CAS算法实现...

    加锁方法对于Map

    而HashMap和TreeMap等非线程安全的Map实现,在多线程环境下如果需要保证线程安全,我们需要手动添加锁。 对于HashMap,我们可以使用synchronized关键字来同步整个操作,例如: ```java Map, String&gt; map = new ...

    大数据基础复习

    相比普通的HashMap,ConcurrentMap允许在多线程环境下并发地读写而不需外部同步。常见的实现类有: - ConcurrentHashMap:线程安全的并发哈希映射,它是ConcurrentMap的最常见实现,通过分段锁技术实现高并发性能。...

    Brian Goetz - 构造一个更好的hashmap

    这个集合类是为了解决传统线程安全的哈希表(如Hashtable和synchronizedMap)在高并发场景下的性能问题而设计的。ConcurrentHashMap相比于传统的线程安全哈希表,其在保证线程安全的同时,能够提供更高的并发性,...

    dashmap:为Rust快速燃烧并发HashMap

    除了dashmap,Rust社区还提供了其他并发HashMap实现,如`parking_lot::Mutex&lt;HashMap, V&gt;&gt;`或`crossbeam::map::HashMap`。每种实现都有其特定的优势和适用场景。例如,parking_lot的Mutex在单线程性能上可能更优,而...

Global site tag (gtag.js) - Google Analytics