【Hash Function and HashMap】

散列函数(Hash Function)是一种将任意大小的数据映射到固定大小值的函数。在 HashMap 中,它扮演着核心角色。让我详细解释:

  1. 散列函数基本原理
  • 输入:任意类型的键(key)
  • 输出:固定大小的整数(哈希码)
  • 目标:将键均匀分布到数组(哈希表)中
  1. 在 HashMap 中的工作流程
// 简化的散列过程
int hashCode = key.hashCode(); // 获取哈希码
int index = hashCode % array.length; // 计算存储位置
  1. 理想的散列函数特征
  • 计算速度快
  • 冲突率低
  • 分布均匀
  • 确定性(相同输入产生相同输出)
  1. 常见散列函数示例
// Java String 的 hashCode 实现
public int hashCode() {int hash = 0;for (char c : value) {hash = 31 * hash + c;}return hash;
}
  1. 处理哈希冲突的方法
  • 链地址法(HashMap 使用)
  • 开放寻址法
  • 再哈希法
  1. 实际应用场景
  • 数据存储
  • 缓存
  • 安全加密
  • 负载均衡

散列函数就像是给数据一个独特的"地址",让 HashMap 能快速存储和查找数据!

  1. 哈希冲突处理方法详解:

链地址法(HashMap使用):

  • 每个数组位置是一个链表/红黑树
  • 冲突的元素追加到同一位置的链表中
  • 当链表长度超过8时转为红黑树
  • 时间复杂度 O(1) 到 O(n)
// 简化的链地址法结构
Node[] table = new Node[16];
class Node {K key;V value;Node next; // 指向下一个节点
}

开放寻址法:

  • 发生冲突时,向后探测空位置
  • 线性探测:逐个向后找空位
  • 平方探测:按平方距离查找
  • 适合数据量小的场景

再哈希法:

  • 冲突时使用另一个哈希函数
  • 计算新的存储位置
  • 减少聚集效应
  • 计算成本较高
  1. 实际应用场景:

数据存储:

  • 数据库索引
  • 缓存系统
  • 快速检索

缓存:

  • Redis 缓存
  • 浏览器缓存
  • 内存缓存

安全加密:

  • 密码存储
  • 数字签名
  • 区块链技术

负载均衡:

  • 分布式系统
  • 服务器请求分配
  • 一致性哈希算法

每种应用都充分利用了哈希函数快速、均匀分布数据的特性。

我来为你详细解析每个应用场景是如何利用哈希函数的特性:

  1. 数据存储

哈希特性:快速定位、均匀分布

// 数据库索引示例
Map<String, UserInfo> userIndex = new HashMap<>();
userIndex.put("userId_10086", new UserInfo());// 快速O(1)查找用户信息
UserInfo user = userIndex.get("userId_10086");

优势:

  • 快速检索
  • 空间利用率高
  • 避免全表扫描
  1. 缓存系统

哈希特性:快速映射、去重

// Redis缓存简化模型
class RedisCache {private Map<String, Object> cache = new HashMap<>();public void set(String key, Object value) {// 哈希函数快速确定存储位置cache.put(key, value);}public Object get(String key) {// O(1)时间复杂度快速获取return cache.get(key);}
}

优势:

  • 毫秒级响应
  • 减少数据库访问
  • 自动去重
  1. 安全加密

哈希特性:唯一性、不可逆

// 密码存储
public class PasswordManager {// 相同输入产生相同哈希值public String hashPassword(String password) {return SHA256(salt + password);}// 验证密码public boolean verify(String input, String storedHash) {return hashPassword(input).equals(storedHash);}
}

优势:

  • 不可逆推原始数据
  • 相同输入始终产生相同结果
  • 防止数据泄露
  1. 负载均衡

哈希特性:均匀分布

// 一致性哈希简化模型
class LoadBalancer {private List<String> servers = new ArrayList<>();public String selectServer(String request) {// 使用哈希函数均匀分配请求int index = request.hashCode() % servers.size();return servers.get(index);}
}

优势:

  • 请求均匀分配
  • 避免单点压力
  • 动态扩展性

关键点:

  • 快速映射
  • 均匀分布
  • 唯一性
  • 低冲突率

哈希函数就像数据世界的"GPS导航",能快速、准确地将数据送达目的地!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/889176.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C/C++流星雨

系列文章 序号直达链接1C/C爱心代码2C/C跳动的爱心3C/C李峋同款跳动的爱心代码4C/C满屏飘字表白代码5C/C大雪纷飞代码6C/C烟花代码7C/C黑客帝国同款字母雨8C/C樱花树代码9C/C奥特曼代码10C/C精美圣诞树11C/C俄罗斯方块12C/C贪吃蛇13C/C孤单又灿烂的神-鬼怪14C/C闪烁的爱心15C/C…

ModelScope-Agent(1): 基于开源大语言模型的可定制Agent系统

目录 简介快速入门 简介 github地址 快速入门 看前两篇&#xff0c;调用千问API和天气API # 选用RolePlay 配置agent from modelscope_agent.agents.role_play import RolePlay # NOQArole_template 你扮演一个天气预报助手&#xff0c;你需要查询相应地区的天气&#x…

【模型对比】ChatGPT vs Kimi vs 文心一言那个更好用?数据详细解析,找出最适合你的AI辅助工具!

在这个人工智能迅猛发展的时代&#xff0c;AI聊天助手已经深入我们的工作与生活。你是否曾在选择使用ChatGPT、Kimi或是百度的文心一言时感到一头雾水&#xff1f;每款AI都有其独特的魅力与优势&#xff0c;那么&#xff0c;究竟哪一款AI聊天助手最适合你呢&#xff1f;本文将带…

微信小程序uni-app+vue3实现局部上下拉刷新和scroll-view动态高度计算

微信小程序uni-appvue3实现局部上下拉刷新和scroll-view动态高度计算 前言 在uni-appvue3项目开发中,经常需要实现列表的局部上下拉刷新功能。由于网上相关教程较少且比较零散,本文将详细介绍如何使用scroll-view组件实现这一功能,包括动态高度计算、下拉刷新、上拉加载等完整…

SQL——DQL分组聚合

分组聚合&#xff1a; 格式&#xff1a; select 聚合函数1(聚合的列),聚合函数2(聚合的列) from 表名 group by 标识列; ###若想方便分辨聚合后数据可在聚合函数前加上标识列&#xff08;以标识列进行分组&#xff09; 常见的聚合函数: sum(列名):求和函数 avg(列名)…

maven打包时出现找不到符号的错误如何解决

在maven打包的时候有时会出现找不到符号的情况&#xff0c;具体原因是由于引用的BaseEntity是framework模块下的实体类&#xff0c;所以需要将framework重新clean再install&#xff0c;成功后再将我们的模块打包就成功了

openGauss开源数据库实战二十一

文章目录 任务二十一 使用JDBC访问openGauss数据库任务目标实施步骤一、准备工作 二、下载并安装JavaSE81 下载JavaSE8安装Java8SE并配置环境变量 三、下载并安装eclipse四、下载并安装openGauss的JDBC驱动包五、使用IDEA编写JDBC测试程序1 使用IDEA的SSH连接虚拟机2 创建项目并…

Git:常用命令

一、查看当前分支 git branch 二、查看所有分支 git branch -a 三、切换到远程分支 git checkout origin/分支名 示例&#xff1a;git checkout origin/dev 四、拉取远程分支代码 git pull origin 分支名 示例&#xff1a;git pull origin dev 五、常用指令 查看暂存区…

运维实战:K8s 上的 Doris 高可用集群最佳实践

今天我们将深入探讨&#xff1a;&#xff1a;如何在 K8s 集群上部署 Compute storage coupled&#xff08;存算耦合&#xff09; 模式的 Doris 高可用集群&#xff1f; 本文&#xff0c;我将为您提供一份全面的实战指南&#xff0c;逐步引导您完成以下关键任务&#xff1a; 配…

在GITHUB上传本地文件指南(详细图文版)

这份笔记简述了如何在GITHUB上上传文件夹的详细策略。 既是对自己未来的一个参考&#xff0c;又希望能给各位读者带来帮助。 详细步骤 打开目标文件夹&#xff08;想要上传的文件夹&#xff09; 右击点击git bash打开 GitHub创立新的仓库后&#xff0c;点击右上方CODE绿色按…

Vue框架入门

Author&#xff1a;Dawn_T17?? 目录 什么是框架 一.Vue 的使用方向 二.Vue 框架的使用场景 &#xff08;TIP&#xff09;MVVM思想 三.Vue入门案例 TIP&#xff1a;插值表达式 四.Vue-指令? &#xff08;1&#xff09;v-bind 和 v-model? ? &#xff08;2&#x…

FPGA 遍历读 LMK04803 寄存器

主要思路&#xff1a; 1.使用 VIO 输出信号控制什么时候开始读LMK04803寄存器 2.遍历LMK04803所有寄存器&#xff0c;将读到的每个寄存器的值显示在VIO上。 3.遍历指的是 从 R0 开始读&#xff0c;R0读完接着读 R1&#xff0c;一直到R31 结束 4.注意的是写寄存器是 32bit &…

【uni-app 微信小程序】新版本发布提示用户进行更新

知识准备 uni.getUpdateManager文档介绍 不支持APP与H5&#xff0c;所以在使用的时候要做好平台类型的判断&#xff0c;如何判断&#xff0c;参考条件编译处理多端差异 代码参考 export const updateApp () > {const updateManager uni.getUpdateManager()updateManag…

vue实现点击左右按钮横向滚动

html部分 <div ref"tabHeaderRef" class"flex items-center tabs_header"><div class"tab-pre" v-if"hidePre" click"leftPre"><i class"el-icon-arrow-left"></i></div><div r…

数据结构(3)单链表的模拟实现

上一节我们进行了数据结构中的顺序表的模拟式现&#xff0c;今天我们来实现一下另外一个数据结构&#xff1a;单链表。 我们在实现顺序表之后一定会引发一些问题和思考&#xff1a; 1.顺序表在头部和中间插入数据会用到循环&#xff0c;时间复杂O&#xff08;N&#xff09; …

uni-app 组成和跨端原理 【跨端开发系列】

&#x1f517; uniapp 跨端开发系列文章&#xff1a;&#x1f380;&#x1f380;&#x1f380; uni-app 组成和跨端原理 【跨端开发系列】 uni-app 各端差异注意事项 【跨端开发系列】uni-app 离线本地存储方案 【跨端开发系列】uni-app UI库、框架、组件选型指南 【跨端开…

操作系统:中断与处理器调度

目录 1、中断与中断系统 中断概念&#xff1a; 中断装置&#xff1a; 中断相关概念&#xff1a; 中断优先级别与中断屏蔽 2、处理机&#xff08;CPU&#xff09;调度 调度相关参数&#xff1a;P62 调度算法&#xff1a; 处理机调度时机 处理机调度过程 3、调度级别与多…

两种距离度量简记

一、Lp距离/Minkowski 距离&#xff08;Minkowski distance&#xff09; 1、Lp距离&#xff1a; 特征空间中两个实例点的距离是两个实例点相似程度的反映。Lp距离是一种一般化的距离度量 设特征空间x是n维实数向量空间Rn xi&#xff0c;xj的Lp距离定义为&#xff08;p>1&…

从零开始的使用SpringBoot和WebSocket打造实时共享文档应用

在现代应用中&#xff0c;实时协作已经成为了非常重要的功能&#xff0c;尤其是在文档编辑、聊天系统和在线编程等场景中。通过实时共享文档&#xff0c;多个用户可以同时对同一份文档进行编辑&#xff0c;并能看到其他人的编辑内容。这种功能广泛应用于 Google Docs、Notion 等…

centos7 离线安装7z

1、下载7-Zip 下载地址&#xff1a;7-Zip - 程序下载 2、解压 mkdir 7zip --创建文件夹7zip mv 7z2301-linux-x64.tar.xz 7zip/ --移动 cd 7zip tar -xvJf 7z2301-linux-x64.tar.xz --解压 输入ll 查看解压后的文件 3、安装cp 7zzs /usr/local/bin/ 输入7zzs 查看是否安装成功…