原文:Hashtable的方法是同步的、线程安全的;HashMap的方法不是同步的、线程不安全。HashMap效率较高,Hashtable效率较低。

同步的意思是加锁的意思 二 HashTable和ConcurrentHashMap的区别: 在进行迭代时,HashTable会锁住整个Map,而ConcurrentHashMap只锁住Map的一部分,所以ConcurrentHashMap在多线程环境下的性能更好。 三 如何让HashMap实现同步功能 Map m Collections.synchronizeMap hashMap 一 HashM ...

2022-01-10 14:52 0 733 推荐指数:

查看详情

HashMap 为什么线程不安全

作者:developer http://cnblogs.com/developer_chan/p/10450908.html 我们都知道HashMap线程不安全的,在多线程环境中不建议使用,但是其线程不安全主要体现在什么地方呢,本文将对该问题进行解密。 1、jdk1.7中 ...

Wed Apr 29 22:14:00 CST 2020 1 1787
HashMap为什么是线程不安全

1、put的时候导致的多线程数据不一致。 这个问题比较好想象,比如有两个线程A和B,首先A希望插入一个key-value对到HashMap中,首先计算记录所要落到的桶的索引坐标,然后获取到该桶里面的链表头结点,此时线程A的时间片用完了,而此时线程B被调度得以执行,和线程A一样执行,只不过线程 ...

Tue Jun 18 23:15:00 CST 2019 0 1905
hashMap线程不安全

hashMap是非线程安全的,表现在两种情况下:   1 扩容:     t1线程对map进行扩容,此时t2线程来读取数据,原本要读取位置为2的元素,扩容后此元素位置未必是2,则出现读取错误数据。   2 hash碰撞     两个线程添加元素发生hash碰撞,都要将此元素添加到链表的头部 ...

Wed Jun 12 19:28:00 CST 2019 0 577
HashMap为什么是线程不安全

HashMap底层是一个Entry数组,当发生hash冲突的时候,hashmap是采用链表的方式来解决的,在对应的数组位置存放链表的头结点。对链表而言,新加入的节点会从头结点加入。 我们来分析一下多线程访问: 1.在hashmap做put操作的时候会调用下面方法 ...

Sun Apr 16 01:02:00 CST 2017 0 10745
为什么HashMap线程不安全

一、Map概述 我们都知道HashMap线程不安全的,但是HashMap的使用频率在所有map中确实属于比较高的。因为它可以满足我们大多数的场景了。 Map类继承图 上面展示了java中Map的继承图,Map是一个接口,我们常用的实现类有HashMap ...

Fri Aug 07 02:04:00 CST 2020 0 484
HashMapHashtable 线程安全

HashMapHashtable的比较是Java面试中的常见问题,用来考验程序员是否能够正确使用集合类以及是否可以随机应变使用多种思路解决问题。HashMap的工作原理、ArrayList与Vector的比较以及这个问题是有关Java 集合框架的最经典的问题。Hashtable是个过时的集合类 ...

Sat Aug 25 00:48:00 CST 2018 0 2445
HashMapHashTable 和 ConcurrentHashMap 线程安全问题

一、HashMap HashMap线程不安全的。 JDK 1.7 HashMap 采用数组 + 链表的数据结构,多线程背景下,在数组扩容的时候,存在 Entry 链死循环和数据丢失问题。 JDK 1.8 HashMap 采用数组 + 链表 + 红黑二叉树的数据结构,优化了 1.7 中数组 ...

Thu Aug 29 05:34:00 CST 2019 0 432
 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM