HashMap、HashSet、Hashtable key/value终极总结

涉及到Hash,即通过Key的哈希值,存取对应value。

注意,同一个key的哈希值必须唯一,不可变。

1、HashMap,key为null时,存在tab[0]中。

value可为空,key的hash不同的话,可存多个。

2、HashSet,采用HashMap,add(value)即采用HashMap的put(value, false)方法,

就是将value作为HashMap的key存入。可存null,只能存一个。

3、Hashtable,多线程安全,synchronized修饰,底层采用map.entry,

源码:value为null都为抛异常。key为null,取其hash为报错。

原因:因为可能涉及多线程,如果value为null,另一个线程取值,就不知道是取到还是没取到。

当然,另一个线程安全的CurrentHashMap,key或者value为null,都不可。原因同Hashtable。

原文地址:https://www.cnblogs.com/codegod/p/8993872.html

时间: 2024-10-07 15:09:55

HashMap、HashSet、Hashtable key/value终极总结的相关文章

ArrayList,Vector,HashMap,HashSet,HashTable之间的区别与联系

看上面的框架图,先抓住它的主干,即Collection和Map. 1 Collection是一个接口,是高度抽象出来的集合,它包含了集合的基本操作和属性. Collection包含了List和Set两大分支. (01) List是一个有序的队列,每一个元素都有它的索引.第一个元素的索引值是0. List的实现类有LinkedList, ArrayList, Vector, Stack. (02) Set是一个不允许有重复元素的集合. Set的实现类有HastSet和TreeSet.HashSet

谈HashMap,HashSet,HashTable容易被我们忽视的问题

在平时开发中,HashMap,HashTable,HashSet 都是经常用到的键值映射数据结构,在这里我主要写一些平时我们使用这些数据结构中容易忽视的问题. HashMap HashMap的结构 HashMap 底层是一个Entry数组来支撑的,我觉得叫Entry链表数组支撑更为合适. 结构图: 每个entry数组里面的元素要么为null要么就是一个entry链表:而每个entry对象就是一个entry链表的节点也是一个键值对的抽象表示: HashMap的性能因素 HashMap主要影响其性能

hashMap,hashTable,hashSet,TreeMap的区别

[hashMap:](键值对,不同步,无序) 存放的是key-value的值,采用put方法:可以存相同的对象.是map的子类: 并允许使用 null 值和 null 键(除了非同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同.) 此类不保证映射的顺序,特别是它不保证该顺序恒久不变. 是无序的. 注意,此实现不是同步的. [hashTable:](对象,同步,无序) 为了成功地在哈希表中存储和获取对象,用作键的对象必须实现 hashCode 方法和 equals

[转]HashMap与HashTable的区别、HashMap与HashSet的关系

转自: http://blog.csdn.net/wl_ldy/article/details/5941770 HashTable的应用非常广泛,HashMap是新框架中用来代替HashTable的类,也就是说建议使用HashMap,不要使用HashTable.可能你觉得HashTable很好用,为什么不用呢?这里简单分析他们的区别. 一:HashMap与HashTable的区别 1.HashTable的方法是同步 的,在方法的前面都有synchronized来同步,HashMap未经同步,所以

HashTable HashMap HashSet区别(java) [From 爱做饭的小莹子]

Hashtable: 1. key和value都不许有null值 2. 使用enumeration遍历 3. 同步的,每次只有一个线程能够访问 4. 在java中Hashtable是H大写,t小写,而HashMap是H大写,M大写 HashMap: 1. key和value可以有null值 2. 使用iterator遍历 3. 未同步的,多线程场合要手动同步HashMap HashSet 1. 底层调用HashMap 2. 不允许有重复值 常用Java操作: 1 Hashtable<Intege

深入源码剖析 HashSet、HashMap、HashTable

HashTable HashTable 是什么 public class Hashtable<K,V> extends Dictionary<K,V> implements Map<K,V>, Cloneable, java.io.Serializable HashTable 是 Java 中哈希表的一种实现形式,它是 Dictionary 的子类,并且实现了 Map 接口. 注1: 哈希表(Hash table,也叫散列表),是根据关键码值(Key value)而直接

HashMap底层实现原理/HashMap与HashTable区别/HashMap与HashSet区别

Hash算法 Hash,一般翻译做"散列",也有直接音译为"哈希"的,就是把任意长度的输入(又叫做预映射, pre-image),通过散列算法,变换成固定长度的输出,该输出就是散列值.这种转换是一种压缩映射,也就是,散列值的空间通常远小于输入的空间,不同的输入可能会散列成相同的输出,而不可能从散列值来唯一的确定输入值.简单的说就是一种将任意长度的消息压缩到某一固定长度的消息摘要的函数. HASH主要用于信息安全领域中加密算法,它把一些不同长度的信息转化成杂乱的128

HashSet HashTable HashMap的区别

(1)HashSet是set的一个实现类,hashMap是Map的一个实现类,同时hashMap是hashTable的替代品(为什么后面会讲到). (2)HashSet以对象作为元素,而HashMap以(key-value)的一组对象作为元素,且HashSet拒绝接受重复的对象.HashMap可以看作三个视图:key的Set,value的Collection,Entry的Set. 这里HashSet就是其实就是HashMap的一个视图. HashSet内部就是使用Hashmap实现的,和Hash

HashMap与HashTable、HashSet与HashMap异同

1. HashMap与HashTable的区别: (1)HashMap允许将null作为一个entry的key或者value,而Hashtable不允许.当get()方法返回null值时,即可以表示HashMap中没有该键,也可以表示该键所对应的值为null.因此,在HashMap中不能由get()方法来判断HashMap中是否存在某个键,而应该用containsKey()方法来判断. (2)HashMap把Hashtable的contains方法去掉了,改成containsvalue和cont