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

容易崩的几个边界点

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

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

要不要手写双向链表

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

Devv
Devv

Devv是一个专为程序员打造的新一代AI搜索引擎

下载

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

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

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

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

23

2025.11.16

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

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

77

2025.09.05

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

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

41

2025.11.16

golang map原理
golang map原理

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

67

2025.11.17

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

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

47

2025.11.27

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

1

2026.03.17

多环境下的 Nginx 安装、结构与运维实战
多环境下的 Nginx 安装、结构与运维实战

本专题聚焦多环境下Nginx实战,详解开发、测试及生产环境的差异化安装策略与目录结构规划。深入剖析配置模块化设计、灰度发布流程及跨环境同步机制。结合监控告警、故障排查与自动化运维工具,提供全链路管理方案,助力团队构建灵活、高可用的Nginx服务体系,从容应对复杂业务场景挑战。

0

2026.03.17

PS 批量添加图片
PS 批量添加图片

本专题整合了PS批量添加图片教程合集,阅读专题下面的文章了解更多详细操作。

0

2026.03.17

Nginx 基础架构:从安装配置到系统化管理
Nginx 基础架构:从安装配置到系统化管理

本专题深入解析Nginx基础架构,涵盖从源码编译与包管理安装,到核心配置文件优化及虚拟主机部署。进一步探讨日志轮转、性能调优、高可用集群构建及自动化运维策略,助力管理员实现从单一服务搭建到企业级系统化管理的全面升级,确保Web服务高效、稳定运行。

1

2026.03.17

热门下载

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

精品课程

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

共1课时 | 0.1万人学习

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

共13课时 | 1.0万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

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

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