LRU缓存
2021/11/15 23:10:34
本文主要是介绍LRU缓存,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
LRUCache
template<typename K, typename V> class LRUCache { public: LRUCache(int cap) : cap_(cap) {} void Set(const K &key, const V &value) { auto item = hash_.find(key); if (hash_.end() == item) { Add(key, value); } else { Change(key, value); } } V Get(const K &key) { auto item = hash_.find(key); if (hash_.end() == item) { return V(-1); } V val = item->second->second; Change(key, val); return val; } void Add(const K &key, const V &value) { if (cache_.size() + 1 > cap_) { Del(cache_.back().first); } cache_.push_front(make_pair(key, value)); hash_[key] = cache_.begin(); } void Del(const K &key) { auto item = hash_.find(key); cache_.erase(item->second); hash_.erase(key); } void Change(const K &key, const V &value) { Del(key); Add(key, value); } private: int cap_; list<pair<K, V>> cache_; unordered_map<K, decltype(cache_.begin())> hash_; };
这篇关于LRU缓存的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-11有哪些好用的家政团队管理工具?
- 2025-01-11营销人必看的GTM五个指标
- 2025-01-11办公软件在直播电商前期筹划中的应用与推荐
- 2025-01-11提升组织效率:上级管理者如何优化跨部门任务分配
- 2025-01-11酒店精细化运营背后的协同工具支持
- 2025-01-11跨境电商选品全攻略:工具使用、市场数据与选品策略
- 2025-01-11数据驱动酒店管理:在线工具的核心价值解析
- 2025-01-11cursor试用出现:Too many free trial accounts used on this machine 的解决方法
- 2025-01-11百万架构师第十四课:源码分析:Spring 源码分析:深入分析IOC那些鲜为人知的细节|JavaGuide
- 2025-01-11不得不了解的高效AI办公工具API