hashmap底层:jdk1.8前后的改变
将hashmap和currenthashmap放一块进行比较,是因为二者的结构相差不多,只不过后者是线程安全的。
首先说hashmap,在jdk1.8之前,hashmap的存储结构是数组+链表的形式,可以理解为元素为链表的数组,当添加一个kv对,首先计算key的哈希值,用哈希值对数组长度按位与,以此确定插入的位置,若该位置已有元素,则形成链表,同一链表元素的哈希值相同,当链表数组容量超过初始容量0.75时,将数组扩大一倍。
由上可以看出,当数据量很大时,每一个位置的链表会变得很长,而链表的平均查找长度是n/2,查找耗时很大。
因此jdk1.8后hashmap的存储结构更新为桶+链表/红黑树的形式,和之前相差不多,只不过在对链表长度的反应上做出了改变,当链表长度超过8,链表自动转化为红黑树的形式,当长度小于6,仍为链表,这是因为:红黑树的平均查找长度是log(n),当n=8,平均查找长度是3,链表平均查找长度是4,此时才有转换为红黑树的必要。而之所以采用红黑树,就是因为红黑树查找效率高(它是个二叉平衡树)。
那为什么使用6和8作为链表和红黑树的分割?
这是因为链表到红黑树的转化过程十分耗费资源,选择6和8,而不是7,就是为了避免频繁增删数据时,不断转换耗费大量资源。
hashmap底层:jdk1.8前后的改变的更多相关文章
- jdk1.8源码解析:HashMap底层数据结构之链表转红黑树的具体时机
		本文从三个部分去探究HashMap的链表转红黑树的具体时机: 一.从HashMap中有关“链表转红黑树”阈值的声明: 二.[重点]解析HashMap.put(K key, V value)的源码: 三 ... 
- Java面试必问之Hashmap底层实现原理(JDK1.7)
		1. 前言 Hashmap可以说是Java面试必问的,一般的面试题会问: Hashmap有哪些特性? Hashmap底层实现原理(get\put\resize) Hashmap怎么解决hash冲突? ... 
- Java基础系列--HashMap(JDK1.8)
		原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/10022092.html Java基础系列-HashMap 1.8 概述 HashMap是 ... 
- HashMap底层结构、原理、扩容机制
		https://www.jianshu.com/p/c1b616ff1130 http://youzhixueyuan.com/the-underlying-structure-and-princip ... 
- HashMap底层数据结构和算法解析
		1.Hash Map的数据结构? A:哈希表结构(链表散列:数组+链表)实现,结合数组和链表的优点.当链表长度超过8时,链表转换为红黑树. transient Node<K,V>[] ta ... 
- hashMap 底层原理+LinkedHashMap 底层原理+常见面试题
		1.源码 java1.7 hashMap 底层实现是数组+链表 java1.8 对上面进行优化 数组+链表+红黑树 2.hashmap 是怎么保存数据的. 在hashmap 中有这样一个结构 ... 
- HashMap底层实现原理
		HashMap底层实现 HashMap底层数据结构如下图,HashMap由“hash函数+数组+单链表”3个要素构成 通过写一个迷你版的HashMap来深刻理解 MyMap接口,定义一个接口,对外暴露 ... 
- HashMap 底层分析
		以下基于 JDK1.7 分析 如图所示,HashMap底层是基于数组和链表实现的,其中有两个重要的参数: ---容量 ---负载因子 容量的默认大小是16,负载因子是0.75,当HashMap的siz ... 
- 最简单的HashMap底层原理介绍
		HashMap 底层原理 1.HashMap底层概述 2.JDK1.7实现方式 3.JDK1.8实现方式 4.关键名词 5.相关问题 1.HashMap底层概述 在JDK1.7中HashMap采用的 ... 
随机推荐
- Flink处理函数实战之一:深入了解ProcessFunction的状态(Flink-1.10)
			欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ... 
- 对App应用架构搭建的一些思考
			当下随着App开发技术的越来越成熟,多人协同开发必不可少,一个团队中每个人的代码风格.技术栈都存在差异,因此统一一套成熟的开发架构必不可少,可以提高开发效率.统一代码风格.为项目维护提供便利. 当下A ... 
- 使用Actor模型管理Web Worker多线程
			前端固有的编程思维是单线程,比如JavaScript语言的单线程.浏览器JS线程与UI线程互斥等等,Web Woker是HTML5新增的能力,为前端带来多线程能力.这篇文章简单记录一下搜狗地图WebG ... 
- FL Studio采样设置之时间拉伸栏
			今天小编将带领大家了解一下FL Studio采样设置页面中的时间拉伸栏知识,该栏目包含了和采样音频的时间拉伸相关的设置.其右边是一个时间伸缩方式下拉列表,里面列出了很多种类的伸缩方式,自动方式是默认的 ... 
- Mac专用下载器Folx软件中有没有“下载速度控制”功能
			Mac专用下载器Folx软件不仅下载速度快,功能多,而且也可以实现下载上传速度控制的功能.下面小编将在Mac系统平台上,使用Folx 5版本,向大家全面介绍下Folx这款下载软件的速度控制功能,其中包 ... 
- Codeforces Round #656 (Div. 3) 题解
			A. Three Pairwise Maximums #构造 题目链接 题意 给定三个正整数\(x,y,z\),要求找出正整数\(a,b,c\),满足\(x=max(a,b), y=max(a,c), ... 
- Java基础教程——泛型
			泛型 Generics:泛型,愿意指"无商标的". 泛型,可以理解为"宽泛的数据类型",就是将类型由原来的具体的类型泛化. 泛型在建立对象时不指定类中属性的具体 ... 
- 使用github actions 完成一些自动化工作
			github actions 是什么? github actions是github的持续集成及自动化工作流服务,使用起来都比较方便.大部分github actions都可以在https://githu ... 
- Spring Boot 实现看门狗功能 (调用 Shell 脚本)
			需要实现看门狗功能,定时检测另外一个程序是否在运行,使用 crontab 仅可以实现检测程序是否正在运行,无法做到扩展,如:手动重启.程序升级(如果只需要实现自动升级功能可以使用 inotify)等功 ... 
- 0001_20190327_使用frp搭建内网穿透
			1. 环境 a) 公网服务器为阿里云的ECS Windows 2008 R2服务器, 有公网IP地址; 这个作为frp的服务器 b) 内网是开发服务器, Cento ... 
