为什么hashmap线程不安全?

作者&投稿:逯凤 (若有异议请与网页底部的电邮联系)
~ 设计hashmap,与hashtable 的原因:
已知线程同步需要消耗一定的时间来达到数据的一至性,
hashmap中所有函数 没有去检查在其它线程中的使用情况下就进行操作了。所以导致了数据
操作结果不理想,但速度较快,适用使用在函数内部作为局部变量,
hashtable 则所有函数声明了线程同步的 synchronized ,所以hashtable 在线程中是安全的,但速度较慢,适应于成员变量


HashMap是什么东西
HashMap,中文名哈希映射,HashMap是一个用于存储Key-Value键值对的集合,每一个键值对也叫做Entry。这些个键值对(Entry)分散存储在一个数组当中,这个数组就是HashMap的主干。HashMap数组每一个元素的初始值都是Null。HashMap是基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用...

什么是HashMap
HashMap是基于hashing实现的,当进行put操作时,根据传递的key值得到它的hashcode,然后再用这个hashcode与数组的长度进行模运算,得到一个int值,就是Entry要存储在数组的位置(下标);当通过get方法获取指定key的值时,会根据这个key算出它的hash值(数组下标),根据这个hash值获取数组下标对应的Entry,...

hashset和hashmap的区别和联系是什么?
HashSet和HashMap是Java中的两个重要的集合类型,它们的区别在于存储方式和特性,而它们的联系是都属于Java集合框架的一部分。HashSet是无序的不重复元素集合,基于HashMap实现;而HashMap则是键值对的映射表。它们都在数据存储和检索上具有很高的性能。接下来详细介绍它们的不同之处和关联之处。HashSet和...

map有哪些常用类 各有什么特点
一、HashMap 特点:基于哈希表的 Map 接口实现,提供键到值的映射关系。它允许使用 null 键和 null 值,并且在哈希表中进行查找、插入和删除操作的时间复杂度都是O(1)。但需要注意,当实际容量超过其设计容量时,HashMap 会进行再哈希操作,这可能导致性能下降。二、TreeMap 特点:基于红黑树实现的 ...

hashset和hashmap的区别和联系是什么?
在***.util包中,hashset和hashmap是两个重要的数据结构,它们在存储元素和功能上有着显著的区别。首要的区别在于存储内容:HashSet专门用于存储唯一的对象,不允许重复,它通过对象自身的hashcode值进行存储。 相反,HashMap则存储键值对,每个键都对应一个值,这对于需要关联存储数据的情况更为适用。在...

hashmap实现了什么接口
HashMap是基于哈希表的Map接口的实现,以key-value的形式存在。在HashMap中,key-value总是会当作一个整体来处理,系统会根据hash算法来计算key-value的存储位置,在使用时,总是可以通过key快速地存、取value。HashMap的key与value类型可以相同也可以不同。可以是字符串(String)类型的key和value,也...

hashset和hashmap的区别和联系是什么?
hashset和hashmap的区别为:存储不同、放入方法不同、hashcode值不同。hashset和hashmap都是存在于java.util包中的类,用于存储数据,且都不允许集合中出现重复的元素。一、存储不同 1、hashset:HashSet仅仅存储对象。2、hashmap:HashMap储存键值对。二、放入方法不同 1、hashset:hashset使用add()...

hashmap和concurrenthashmap的区别是什么?
HashMap:底层数组+链表实现,可以存储null键和null值,线程不安全。初始size为16,扩容:newsize = oldsize*2,size一定为2的n次幂。扩容针对整个Map,每次扩容时,原来数组中的元素依次重新计算存放位置,并重新插入。插入元素后才判断该不该扩容,有可能无效扩容(插入后如果扩容,如果没有再次插入,...

Java中HashMap和LinkedHashMap以及TreeMap的区别
HashMap,LinkedHashMap,TreeMap都属于Map;Map 主要用于存储键(key)值(value)对,根据键得到值,因此键不允许键重复,但允许值重复。不同点:1.HashMap里面存入的键值对在取出的时候是随机的,也是我们最常用的一个Map.它根据键的HashCode值存储数据,根据键可以直接获取它的值,具有很快的访问速度。在...

HashMap和LinkedHashMap的区别是什么?
HashMap是一个最常用的Map,它根据键的hashCode值存储数据,根据键可以直接获取它的值,具有很快的访问速度。HashMap最多只允许一条记录的键为NULL,允许多条记录的值为NULL。HashMap不支持线程同步,即任一时刻可以有多个线程同时写HashMap,可能会导致数据的不一致性。如果需要同步,可以用Collections的...

秀山土家族苗族自治县18377613914: hashmap 为什么线程不安全 -
姜侵妇宁: 有2种办法让HashMap线程安全,分别如下:方法一:通过Collections.synchronizedMap()返回一个新的Map,这个新的map就是线程安全的. 这个要求大家习惯基于接口编程,因为返回的并不是HashMap,而是一个Map的实现.方法二:重新改写了HashMap,具体的可以查看java.util.concurrent.ConcurrentHashMap. 这个方法比方法一有了很大的改进.

秀山土家族苗族自治县18377613914: hashmap为什么是线程不安全的 -
姜侵妇宁: HashMap底层是一个Entry数组,当发生hash冲突的时候,hashmap是采用链表的方式来解决的,在对应的数组位置存放链表的头结点.对链表而言,新加入的节点会从头结点加入.javadoc中关于hashmap的一段描述如下:此实现不是同步的....

秀山土家族苗族自治县18377613914: hashmap为什么不是线程安全的 -
姜侵妇宁: 此实现不是同步的.如果多个线程同时访问一个哈希映射,而其中至少一个线程从结构上修改了该映射,则它必须 保持外部同步.(结构上的修改是指添加或删除一个或多个映射关系的任何操作;仅改变与实例已经包含的键关联的值不是结构上的修改.)这一般通过对自然封装该映射的对象进行同步操作来完成.如果不存在这样的对象,则应该使用 Collections.synchronizedMap 方法来“包装”该映射.最好在创建时完成这一操作,以防止对映射进行意外的非同步访问,如下所示:

秀山土家族苗族自治县18377613914: 如何线程安全的使用HashMap -
姜侵妇宁: 在周二面试时,一面的面试官有问到HashMap是否是线程安全的,如何在线程安全的前提下使用HashMap,其实也就是HashMap,Hashtable,ConcurrentHashMap和synchronized Map的原理和区别.当时有些紧张只是简单说了下HashMap不是线...

秀山土家族苗族自治县18377613914: hashmap多线程为什么造成死循环 -
姜侵妇宁: 一直以来只是知道HashMap是线程不安全的,但是到底HashMap为什么线程不安全,多线程并发的时候在什么情况下可能出现问题? HashMap底层是一个Entry数组,当发生hash冲突的时候,hashmap是采用链表的方式来解决的,在对应的数组位置存放链表的头

秀山土家族苗族自治县18377613914: java hashset为什么线程不安全 -
姜侵妇宁: 安全和效率的zd问题 table虽然线程安全, 但是效率底 我们很多时候不会考虑到多线程的问题, 所以正确的做法就是如果需要专属, 使用效率高的hashmap而同时自己去同步, 而不是为了少写点编码, 而不管需要不需要同步都去使用效率低的hashtable

秀山土家族苗族自治县18377613914: 请教高手Hashtable、HashMap、HashSet的用法与区别? -
姜侵妇宁: 他们的区别:HashTable和HashMap是Map接口的实现类,其中HashTable的键或值不能为null,HashMap的键或值可以为null;HashTable是线程安全的,HashMap是线程不安全的,因此HashMap的效率要比HashTable高.HashSet是Set接口的实现...

秀山土家族苗族自治县18377613914: hashmap是线程安全还是不安全的 -
姜侵妇宁: String, Interger这样的wrapper类作为HashMap的键是再适合不过了,而且String最为常用.因为String是不可变的,也是final的,而且已经重写了equals()和hashCode()方法了.其他的wrapper类也有这个特点.不可变性是必要的,因为为了...

秀山土家族苗族自治县18377613914: hashmap 是线程安全的吗 -
姜侵妇宁: Hashtable. 1 HashMap不是线程安全的hastmap是一个接口 是map接口的子接口,是将键映射到值的对象,其中键和值都是对象,并且不能包含重复键,但可以包含重复值.HashMap允许null key和null value,而hashtable不允许.2 HashTable...

秀山土家族苗族自治县18377613914: Java中HashMap和TreeMap的区别深入理解 -
姜侵妇宁: HashMap:数组方式存储key/value,线程非安全,允许null作为key和value,key不可以重复,value允许重复,不保证元素迭代顺序是按照插入时的顺序,key的hash值是先计算key的hashcode值,然后再进行计算,每次容量扩容会重新计算所以key...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网