头条面试题:如何实现 LRU 原理?

栏目: 数据库 · 发布时间: 4年前

内容简介:下面开始今天的学习~

点击上方 蓝字 关注我们

下面开始今天的学习~

头条面试题:如何实现 LRU 原理?

LRU 原理作为操作系统课程中的一个重要部分在很多地方会被考到(比如操作系统课的考试或者一些公司的面试题)。

LRU 算法的设计原则是:如果一个数据在最近一段时间没有被访问到,那么在将来它被访问的可能性也很小。也就是说,当限定的空间已存满数据时,应当把最久没有被访问到的数据淘汰。

这个算法的出发点在于:如果某个页面被访问了,则它可能马上还要访问。反之,如果很长时间未被访问,则它在最近一段时间也不会被访问。

该算法的性能接近于最佳算法,但实现起来较困难。因为要找出最近最久未使用的页面,必须为每一页设置相关记录项,用于记录页面的访问情况,并且每访问一次页面都须更新该信息。这将使系统的开销加大,所以在实际系统中往往使用该算法的近似算法。

对于考试题目而言,由于一般是卷面考试,所以我们通常需要完成的是在纸上描绘出 LRU 的置换原理,一般题目如下:

最近最久未使用算法例

假定系统为某进程分配了 3 个物理块,进程运行时的页面走向为 1,2,3,4,1,2,5,1,2,3,4,5,开始时 3 个物理块均为空,计算采用   最近最久未使用页面淘汰算法时的缺页率  ?(10/12)

头条面试题:如何实现 LRU 原理?

对于面试而言,可能就不仅仅是「明白概念」+「画出示例」那么简单了,可能还需要自己动手去实现一个 LRU 算法的小 Demo。

146.LRU缓存机制

在力扣上有这么一道题:

头条面试题:如何实现 LRU 原理?

并且给出了提示——在 O(1) 时间复杂度内完成 get 和 put 操作。

一个比较通用的做法是通过 Hashmap + Double Linked List 来完成,图示如下:

头条面试题:如何实现 LRU 原理?

这样,整个数据的操作过程如下:

头条面试题:如何实现 LRU 原理?

实现算法代码如下:

头条面试题:如何实现 LRU 原理?

Redis

Redis LRU algorithm is not an exact implementation. This means that Redis is not able to pick the best candidate for eviction, that is, the access that was accessed the most in the past. Instead it will try to run an approximation of the LRU algorithm, by sampling a small number of keys, and evicting the one that is the best (with the oldest access time) among the sampled keys.

Redis 是一个著名的键值对数据库,在   Using Redis as an LRU cache   中我 们知道 Redis 可以用来做为 LRU 缓存(虽然不是一个非常标准的实现,因为 Redis 可能无法选出最佳换出项),Redis 的方法是随机取出若干个 key,然后按照访问时间 排序 后,淘汰掉最不经常使用的页面,一个较为详尽的分析在参考资料中已经有所提及,建议有兴趣的读者参考。

参考资料

1. LRU原理和Redis实现——一个今日头条的面试题

2.LeetCode 算法题解——LRU 缓存机制

头条面试题:如何实现 LRU 原理?

本文作者:Nova Kwok

编辑&版式:霍霍

声明:本文归 “力扣” 版权所有,如需转载请联系。

推荐阅读

头条面试题:如何实现 LRU 原理?

头条面试题:如何实现 LRU 原理?

头条面试题:如何实现 LRU 原理?

头条面试题:如何实现 LRU 原理?

头条面试题:如何实现 LRU 原理?

头条面试题:如何实现 LRU 原理?

头条面试题:如何实现 LRU 原理?

头条面试题:如何实现 LRU 原理?


以上所述就是小编给大家介绍的《头条面试题:如何实现 LRU 原理?》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

产品经理必懂的技术那点事儿

产品经理必懂的技术那点事儿

唐韧 / 电子工业出版社 / 2017-1 / 59

《产品经理必懂的技术那点事儿》以非技术背景产品经理了解技术为主题,将技术知识以简单并且易于理解的方式讲述出来,帮助非技术背景产品经理了解技术、学习技术,旨在帮助产品经理高效地与技术人员进行沟通与合作。 《产品经理必懂的技术那点事儿》的主要内容围绕产品经理需要了解的互联网基础技术知识展开,涉及客户端、服务器端、数据库及一些数据处理知识。同时,还就产品经理需具备的一些软实力,例如沟通能力和解决问......一起来看看 《产品经理必懂的技术那点事儿》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具