HashMap的底层原理及其数据结构

HashMap结合了数组和链表的特性,通过哈希算法快速定位数据。其特点包括快速存储、查找及可伸缩性。哈希算法通过key的hashCode进行计算,当哈希冲突时,使用链表处理,链表过长则转为红黑树,以保持高效查找。当数组容量达到75%时触发扩容,扩容为原长度的两倍。
摘要由CSDN通过智能技术生成

HsahMap的底层原理

hashMap是Java语言中遇到的最常用的数据结构
1、hashMap的数据结构
要了解hashmap首先要弄清楚他的数据结构,在java编程中,最基本的数据结构有两种,数组和链表。
数组:查询速度快,可以根据索引查询,但是插入和删除比较困难。
链表:查询速度慢,需要遍历整个链表,但是插入和删除比较容易。
HashMap是数组和链表组成的,数据结构又叫链表散列。
2.hashmap特点

  1. 快速存储 :比如当我们对hashmap进行get和put的时候速度非常快
  2. 快速查找(时间复杂度o(1))当我们通过key去get一个value的时候时间复杂度非常的低,效率非常高
  3. 可伸缩:1数组扩容,边长。2,单线列表如果长度超过8的话会变成红黑树
    3.hashmap的Hash算法
    在聊哈算法之前我们要知道在Java中所有对象都有hashcode(使用key的),如果使用object对象get hashcode的话会得到要给int类型的指,我们在hashmap中主要是用他的key去计算它的值的。

Hash值的计算

Hash值=(hashcode)^(hashcode >>> 16)
Hashcode予hashcode自己向右位移16位的异或运算。这样可以确保算出来的值足够随机。因为进行hash计算的时候足够分散,以便于计算数组下标的时候算的值足够分散。前面说过hashmap的底层是由数组组成&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值