首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Hashtable实现原理

K,V>, Cloneable, java.io.Serializable{} 从源码中,我们可以看出,Hashtable 继承于 Dictionary 类,实现了 Map, Cloneable, java.io.Serializable...该话指出 Dictionary 这个类过时了,新的实现类应该实现Map接口。 Hashtable 源码解读 成员变量 Hashtable是通过"拉链法"实现的哈希表。...modCount 是用来实现 fail-fast 机制的。 关于变量的解释在源码注释中都有,最好还是应该看英文注释。...Dictionary 是任何可将键映射到相应值的类的抽象父类,而 AbstractMap 是基于 Map 接口的实现,它以最大限度地减少实现此接口所需的工作。...我们可以看一下源码,Hashtable 中的几乎所有的 public 的方法都是 synchronized 的,而有些方法也是在内部通过 synchronized 代码块来实现

57120
您找到你想要的搜索结果了吗?
是的
没有找到

HashTable原理和底层实现

概述 上次讨论了HashMap的结构,原理和实现,本文来对Map家族的另外一个常用集合HashTable进行介绍。HashTable和HashMap两种集合非常相似,经常被各种面试官问到两者的区别。...但是HashTable中是不允许保存null的。 HashMap的迭代器(Iterator)是fail-fast迭代器,但是Hashtable的迭代器(enumerator)不是fail-fast的。...HashTable类继承自Dictionary类,实现了三个接口,分别是Map,Cloneable和java.io.Serializable,如下图所示。 ?...HashTable中的主要方法,如put,get,remove和rehash等,与HashMap中的功能相同,这里不作赘述,可以参考另外一篇文章HashMap原理和底层实现 3....源码分析 HashTable的主要方法的源码实现逻辑,与HashMap中非常相似,有一点重大区别就是所有的操作都是通过synchronized锁保护的。只有获得了对应的锁,才能进行后续的读写等操作。

2.8K30

Hashtable 为什么不叫 HashTable

前几天在写《HashMap 和 Hashtable 的 6 个区别》这篇文章的时候,差点把 Hashtable 写成了 HashTable,后来看源码证实了是:Hashtable,小写的 "t"able...当时就很好奇,Hashtable 为什么不是 HashTable 呢? 作为一名初级的 Java 程序员都应该知道的基本的驼峰命名规则,为什么 JDK 代码里面还有这种不规范的命名呢?...最佳答案是: Hashtable was created in Java v1....顺便说一下,这样就使得 Hashtable 过时了,所以不应该在新代码中继续使用它。 栈长看了下,Hashtable 确实是 JDK1.0 添加的,最早的一个集合类,这样也说得过去。...另外,关于《HashMap 和 Hashtable 的 6 个区别》,有人留言说可以使用 currenthashtable。 ?

59230

【java源码】解读HashTable类背后的实现细节

HashTable这个类实现了哈希表从key映射到value的数据结构形式。任何非null的对象都可以作为key或者value。...要在hashtable中存储和检索对象,作为key的对象必须实现hashCode、equals方法。 一般来说,默认的加载因子(0.75)提供了一种对于空间、时间消耗比较好的权衡策略。...如果有大量的数据需要放进hashtable,则选择设置较大的初始容量比它自动rehash更优。 在Java平台v1.2中,这个类被重新安装以实现Map接口,使它成为Java集合框架的成员。...与新的集合实现不同,Hashtable是同步的。如果不需要线程安全的实现,建议使用HashMap代替Hashtable。...如果想要一个线程安全的高并发实现,那么建议使用java.util.concurrent.ConcurrentHashMap取代了Hashtable

16020

Hashtable源码解析

今天我们来分析一下Hashtable的底层实现。提到Hashtable可能对于有些人来说会比较陌生,因为不经常使用。这是因为Hashtable是很早就有的集合类了,因为它是在JDK1.0版本中存在的。...所以它们底层的实现方式几乎是一样,但它们也有些不同的地方要注意,并且它们都是用哈希表的方式存储的。...既然我们已经掌握了HashMap的底层实现,那么我们在分析Hashtable时会比较容易,所以本篇中将直接分析Hashtable的底层源码,将不在介绍哈希表的相关知识了。...而在Hashtable中,不但设置了默认的加载因子为0.75,并且已经将底层的数组初始化了。默认初始化的数组大小为为了11。 下面我们看一下Hashtable中的put方法的底层实现逻辑。 ? ?...value Hashtable不能保存相同的key元素,如果元素的key相同,则将后添加到Hashtable中的元素的value覆盖原Hashtable已经存在的元素的value Hashtable执行再散列时

42820

HashTable源码学习

在之前学习HashMap的时候,我们知道在JDK8中HashMap是采用Node数组+链表+红黑树的方式实现的。那么HashTable又是怎样的? 字面上看应该还是利用的Hash表来处理的。...那么我们基于这样一点知识来学习一下HashTable的设计和实现过程。 ? 从结构上看,HashTable的结构也没有HashMap那么复杂。所以实现起来应该还是比较简单吧。...比如table、threshold、loadFactor,似乎说明HashTable也仅仅是HashMap的小弟弟。那么是这样吗?咋从初始化方法看起。...this(11, 0.75f); } public Hashtable(Map<?...而且看的出来Hashtable相比与HashMap还是相当的保守呀。 那么在添加元素的时候,hashtable又是如何做的呐?是否和hashmap一样?

34220

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券