Javascript中哈希表的实现

一、什么是哈希表?

哈希表是一种数据结构,可以快速存储和查找键值对(Key-Value Pairs)。它的核心思想是:

  1. 通过哈希函数:将一个键(Key)转换成唯一的数字(哈希值)。
  2. 用这个数字作为索引,直接找到对应的值(Value)。

举个栗子🌰:

  • 假设你有一个电话簿,名字是"键",电话号码是"值"。
  • 哈希表就像直接通过名字的拼音首字母(哈希函数)快速找到对应的电话号码。

二、JavaScript 中的哈希表实现

JavaScript 没有直接的"哈希表"类型,但可以通过以下三种方式实现类似功能:

1. 普通对象(Object)

javascript 复制代码
const phoneBook = {};
phoneBook["Alice"] = "123-456";  // 添加键值对
console.log(phoneBook["Alice"]); // 输出 "123-456"(查找)
  • 缺点:键只能是字符串或 Symbol,无法用对象作为键。

2. Map(ES6 新增)

javascript 复制代码
const map = new Map();
map.set("Alice", "123-456");     // 添加键值对
console.log(map.get("Alice"));   // 输出 "123-456"(查找)
  • 优点
    • 键可以是任意类型(对象、函数等)。
    • 保持插入顺序(普通对象不保证顺序)。
    • size属性直接获取长度。

3. Set(ES6 新增)

javascript 复制代码
const set = new Set();
set.add(1);          // 添加值
console.log(set.has(1)); // 输出 true(检查存在性)
  • 用途:仅存储唯一的值(自动去重),没有键值对。

三、哈希表的特性

1. 时间复杂度

  • 插入、删除、查找:平均时间复杂度是 O(1)(非常高效!)。
  • 为什么快?哈希函数直接将键映射到内存位置,不需要遍历所有元素。

2. 哈希冲突

  • 问题:不同的键可能生成相同的哈希值(比如 "Alice" 和 "Bob" 哈希后都是 5)。
  • 解决方式
    • 链地址法:同一个索引位置存储一个链表(如 JavaScript 的 Map 内部实现)。
    • 开放寻址法:寻找下一个空槽位。

四、哈希表的应用场景

  1. 快速去重 (用 Set):

    javascript 复制代码
    const arr = [1, 2, 2, 3];
    const unique = [...new Set(arr)]; // [1, 2, 3]
  2. 缓存数据 (用 MapObject):

    javascript 复制代码
    const cache = new Map();
    function getUser(id) {
      if (cache.has(id)) return cache.get(id);
      const user = fetchUserFromDatabase(id); // 假设这是耗时操作
      cache.set(id, user);
      return user;
    }
  3. 统计频率 (用 Object):

    javascript 复制代码
    const str = "hello";
    const count = {};
    for (const char of str) {
      count[char] = (count[char] || 0) + 1;
    }
    // { h:1, e:1, l:2, o:1 }

六、总结

  • 哈希表 的核心是"快速定位数据"。
  • JavaScript 实现 :优先用 MapSet(功能更强大),普通对象适合简单场景。
  • 注意 :哈希函数的设计会影响性能,但 JavaScript 内置的 MapSet 已经帮我们处理好了底层细节。

常见用法:

xml 复制代码
<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <script>
    //js中一共有三种方式实现哈希表
    //1.普通对象
    const hash1 = {};
    //添加:键值对,左边是键,右边是值.
    hash1["苗"]=18;
    // 获取:值
    console.log(hash1["苗"]);

    //2.Map法es6中新增
    const hash2 = new Map();
    //添加
    hash2.set("余",17);
    //获取
    console.log(hash2.get("余"));
    //长度
    console.log(hash2.size);
    
    //3.Set法es6中新增,仅存储唯一值,没有键值对
    const hash3 = new Set();
    //添加
    hash3.add(1);
    //获取,返回值是布尔类型
    console.log(hash3.has(1));
    

    
  </script>
</body>
</html>
相关推荐
五月君_5 小时前
炸裂!Claude Opus 4.6 与 GPT-5.3 同日发布:前端人的“自动驾驶“时刻到了?
前端·gpt
Mr Xu_5 小时前
前端开发中CSS代码的优化与复用:从公共样式提取到CSS变量的最佳实践
前端·css
zheyutao5 小时前
字符串哈希
算法
A尘埃5 小时前
保险公司车险理赔欺诈检测(随机森林)
算法·随机森林·机器学习
鹏北海-RemHusband6 小时前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
网络安全-杰克6 小时前
2026面试自动化测试面试题【含答案】
自动化测试·软件测试·面试·职场和发展
LYFlied6 小时前
AI大时代下前端跨端解决方案的现状与演进路径
前端·人工智能
光影少年6 小时前
AI 前端 / 高级前端
前端·人工智能·状态模式
一位搞嵌入式的 genius6 小时前
深入 JavaScript 函数式编程:从基础到实战(含面试题解析)
前端·javascript·函数式
anOnion6 小时前
构建无障碍组件之Alert Dialog Pattern
前端·html·交互设计