HashTable源码

引子

看到一个关于HashMap和HashTable对比的面试题,于是简单看了下HashTable的源码,简单记录下。

概述

与HashMap相似的哈希表结构,有很多不同点:

  • 节点数组的初始化是在构造函数中完成的,初始容量11,负载因子0.75;
  • hashTable内部使用synchronized实现线程安全;
  • hashTable的k v 都不能为null,否则NPE;
  • 内部使用数组 + 链表的结构,没有链表转红黑树的过程。
  • 添加元素时检测并触发扩容,扩容时,容量是原容量的2倍+1
    注意:

仅做源码学习,不推荐使用。

" 如果不需要线程安全的实现,建议使用HashMap代替Hashtable 。如果需要线程安全的高并发实现,则建议使用java. util. concurrent. ConcurrentHashMap代替Hashtable "

------------来自hashTable类说明

put流程

复制代码
private void addEntry(int hash, K key, V value, int index) {
    Entry<?,?> tab[] = table;
    if (count >= threshold) { // 触发扩容
        // Rehash the table if the threshold is exceeded
        rehash(); // 2倍 +1 扩容,复制数组,重新计算元素的hash

        tab = table;
        hash = key.hashCode();
        index = (hash & 0x7FFFFFFF) % tab.length;
    }

    // Creates the new entry.
    @SuppressWarnings("unchecked")
    Entry<K,V> e = (Entry<K,V>) tab[index];
    tab[index] = new Entry<>(hash, key, value, e);
    count++;
    modCount++;
}

题外话:

与HashMap和ConcurrentHashMap不同的是,hashTable中,put 和 **putIfAbsent **方法是两个独立的方法,竟然没有通过参数传递来复用。重复代码,妥妥的!!!在HashMap和ConcurrentHashMap中,这种情况就没有了😄。

相关推荐
星马梦缘4 小时前
数据库 第十三章 未完结版本
java·网络·数据库
程序猿乐锅4 小时前
【JAVASE | 第十六篇】多线程
java·开发语言
做个文艺程序员4 小时前
第01篇:Redis 从入门到上手:核心数据结构与 Java Spring Boot 实战详解
java·redis数据结构·redis入门·redis教程·java集成redis
影寂ldy4 小时前
C# 多接口、同名冲突、显式实现、接口继承 完整笔记
java·笔记·c#
JAVA面经实录9174 小时前
Spring Cloud Alibaba 微服务企业实战完整文档(架构+规范+调优+故障+源码)
java·运维·spring cloud·微服务
布局呆星4 小时前
Spring Boot + JWT + Spring Security 认证授权实战:双角色、双 Token、方法级权限,一次讲透
java·开发语言
大G的笔记本4 小时前
生产级 Spring Boot 网关完整实现方案
java·笔记·gateway
LucianaiB4 小时前
Swarm管理面板的多项目配置策略与模型别名机制的效率分析
java·服务器·前端
qq_2518364574 小时前
基于Spring Boot的数据标注与质检系统设计与实现
java·spring boot·后端
總鑽風4 小时前
Spring AI实战:快速集成阿里通义千问
java·后端·spring·ai编程