0

0

C++ 怎么实现LRU缓存 C++ 哈希表结合双向链表思路【面试题】

冰火之心

冰火之心

发布时间:2026-01-30 17:30:09

|

499人浏览过

|

来源于php中文网

原创

不能只用 std::unordered_map 因为它不维护访问顺序,无法在 O(1) 内更新最近使用或删除最久未用节点;LRU 需双向链表显式维护时序,配合 unordered_map 存迭代器实现 O(1) 查找与更新。

c++ 怎么实现lru缓存 c++ 哈希表结合双向链表思路【面试题】

为什么不能只用 std::unordered_map

因为哈希表本身不维护访问顺序,std::unordered_map 查得快(O(1)),但没法在 O(1) 时间内把最近访问的节点提到最前面,也没法快速删掉最久未用的节点。LRU 的“最近/最久”依赖的是时序,必须靠链表结构来显式维护——而单向链表删除尾节点是 O(n),所以得用双向链表。

std::liststd::unordered_map 怎么配对用

核心是让两者指向同一份数据,避免拷贝和同步问题:

  • std::list 存完整键值对(比如 std::pair),保证节点顺序可变、增删 O(1)
  • std::unordered_map 的 value 存 std::list<...>::iterator,这样查 key 时能立刻定位到链表中对应节点
  • 每次 get()put() 后,先用迭代器从 list 中 erase() 原位置,再 push_front() 到头部——这步才是“更新最近使用”
  • 注意:std::list 迭代器不会因插入/删除失效(只要不是它自己被删),所以 map 里存的 iterator 在大部分操作后仍有效

容易崩的几个边界点

面试时一写就错的地方,往往不在主逻辑,而在细节:

  • 构造函数里没初始化 capacity,或者忘了检查 capacity 的非法输入
  • put() 时 key 已存在:要更新 value 并移动到头部,**不能直接 insert 新节点**,否则内存泄漏+map 指向旧迭代器
  • 缓存满时删 tail:别用 --cache.end() 取最后一个元素,应该用 cache.back();删完记得从 map 中 erase() 对应的 key
  • 所有涉及 list::erase(iterator) 的地方,确保 iterator 有效——特别是从 map 查不到 key 时,别拿空迭代器去 erase

要不要手写双向链表

LeetCode 和大多数面试场景下,用 std::list 完全合规,且更安全。手写链表只在两种情况有必要:

知识画家
知识画家

AI交互知识生成引擎,一句话生成知识视频、动画和应用

下载

立即学习C++免费学习笔记(深入)”;

  • 题目明确要求“不使用内置链表类”
  • 你需要精细控制内存布局(比如避免 std::list 节点分散分配带来的 cache 不友好)

但手写意味着要自己管理 next/prev 指针、处理空指针、保证 erase 不崩溃——实际工程中极少这么干,面试里除非被追问底层实现,否则优先用标准容器。

真正难的不是结构,是怎么在每次操作里严格维持 map 和 list 的一致性:一个节点在 list 里,map 就必须有对应项;删了 list 节点,map 里那条记录也得立刻消失。漏掉一次,后续所有 get() 都可能解引用野迭代器。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
空指针异常处理
空指针异常处理

本专题整合了空指针异常解决方法,阅读专题下面的文章了解更多详细内容。

22

2025.11.16

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

golang map相关教程
golang map相关教程

本专题整合了golang map相关教程,阅读专题下面的文章了解更多详细内容。

36

2025.11.16

golang map原理
golang map原理

本专题整合了golang map相关内容,阅读专题下面的文章了解更多详细内容。

61

2025.11.17

java判断map相关教程
java判断map相关教程

本专题整合了java判断map相关教程,阅读专题下面的文章了解更多详细内容。

42

2025.11.27

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

9

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

10

2026.01.30

python 字符串格式化
python 字符串格式化

本专题整合了python字符串格式化教程、实践、方法、进阶等等相关内容,阅读专题下面的文章了解更多详细操作。

3

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号