LRU(最近最少使用)缓存数据结构

lru(最近最少使用)缓存数据结构

lru(最近最少使用)缓存是一种缓存,当缓存超出其容量时,它会逐出最近最少访问的项目。它在内存有限且您只想缓存最常访问的数据的场景中非常有用。

在 javascript 中,lru 缓存可以使用 map(用于快速查找和维护插入顺序)和双向链表(用于两端高效插入和删除)的组合来实现。但是,为了简单起见,我们将在以下实现中使用 map。

这是 lru 缓存的 javascript 实现:

class lrucache {    constructor(capacity) {        this.capacity = capacity;        this.cache = new map(); // using map to maintain key-value pairs    }    // get the value from the cache    get(key) {        if (!this.cache.has(key)) {            return -1; // if the key is not found, return -1        }        // key is found, move the key to the most recent position        const value = this.cache.get(key);        this.cache.delete(key); // remove the old entry        this.cache.set(key, value); // reinsert to update its position (most recently used)        return value;    }    // add or update the value in the cache    put(key, value) {        if (this.cache.has(key)) {            // if the key already exists, remove it to update its position            this.cache.delete(key);        } else if (this.cache.size >= this.capacity) {            // if the cache is at capacity, delete the least recently used item            const leastrecentlyusedkey = this.cache.keys().next().value;            this.cache.delete(leastrecentlyusedkey);        }        // insert the new key-value pair (most recent)        this.cache.set(key, value);    }}

说明:
构造函数:lrucache类用给定的容量进行初始化,它使用map来存储缓存的键值对。地图会跟踪插入顺序,这有助于识别最近最少使用 (lru) 的项目。

获取(密钥):

即构数智人 即构数智人

即构数智人是由即构科技推出的AI虚拟数字人视频创作平台,支持数字人形象定制、短视频创作、数字人直播等。

即构数智人 36 查看详情 即构数智人 如果缓存中存在该键,该方法将返回其值,并通过先删除该键然后重新插入该键将键移动到最近的位置。如果键不存在,则返回-1。

put(键,值):

如果缓存中已存在该密钥,则会删除该密钥并重新插入它(将其位置更新为最近使用的位置)。如果缓存达到其容量,它将删除最近最少使用的键(map 中的第一个键)。最后,新的键值对被添加到缓存中。

使用示例:

const lruCache = new LRUCache(3); // Cache with a capacity of 3lruCache.put(1, 'one');   // Add key 1lruCache.put(2, 'two');   // Add key 2lruCache.put(3, 'three'); // Add key 3console.log(lruCache.get(1)); // Output: 'one' (key 1 becomes the most recently used)lruCache.put(4, 'four'); // Cache is full, so it evicts key 2 (least recently used)console.log(lruCache.get(2)); // Output: -1 (key 2 has been evicted)console.log(lruCache.get(3)); // Output: 'three' (key 3 is still in the cache)console.log(lruCache.get(4)); // Output: 'four' (key 4 is in the cache)

以上就是LRU(最近最少使用)缓存数据结构的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/436314.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 16:22:01
下一篇 2025年11月7日 16:26:47

相关推荐

  • c语言环境变量是什么

    C语言环境变量是指存储在操作系统中的一组键值对,包含有关系统配置和用户首选项的信息,可以通过标准C函数getenv()和putenv()访问和修改。常见的环境变量包括PATH、HOME、USER、LANG、EDITOR等。环境变量对于配置和定制系统至关重要,因为它允许程序和脚本访问系统设置和用户首选…

    2025年12月17日
    000
  • XML中如何判断节点类型_XML判断节点类型的方法与步骤

    XML节点类型包括元素、文本、属性、注释和文档节点,正确识别可精准提取或修改数据;2. Python使用xml.dom.minidom通过node.nodeType判断,如ELEMENT_NODE=1、TEXT_NODE=3;3. JavaScript中用DOM的node.nodeType,值为1是…

    2025年12月17日
    000
  • XML与JSON有何区别?如何选择?

    XML结构复杂支持属性和命名空间,适合复杂数据与行业标准;JSON语法简洁体积小,解析高效,适用于Web接口与前后端交互,现代应用多选JSON,传统系统或特定领域仍用XML。 XML和JSON都是数据交换的格式,但它们在结构、语法和使用场景上有明显不同。选择哪种取决于具体需求,比如数据复杂度、可读性…

    2025年12月17日
    000
  • XML在智能家居中的应用

    XML在智能家居中提供统一的数据结构,实现设备间互联互通。其树状标签结构支持设备配置、状态汇报与服务描述,确保多品牌设备协同工作。相比JSON,XML具备更强的Schema验证、命名空间支持和元数据能力,提升系统健壮性与可维护性,但存在文件冗余、解析复杂等挑战。实际应用中,XML常用于设备注册、状态…

    2025年12月17日
    000
  • XML中如何合并节点属性_XML合并节点属性的方法与技巧

    合并XML节点属性需基于唯一标识识别目标节点,通过编程语言(如Python)或XSLT实现属性整合。1. 使用Python的ElementTree解析XML,遍历属性并根据策略(如允许覆盖)合并;2. 利用XSLT模板匹配同名节点,复制源属性并筛选不冲突的目标属性;3. 注意处理属性冲突、确保节点唯…

    2025年12月17日
    000
  • XML中如何处理嵌套属性列表_XML处理嵌套属性列表的方法与技巧

    答案:XML中处理嵌套属性列表需用子元素模拟结构,避免属性存储列表,通过层级元素表达关系,结合属性补充元数据,并选用合适解析方式与设计规范。 在XML中处理嵌套属性列表时,关键在于理解XML的结构特性并合理使用解析技术。XML本身不支持属性的“列表”或“嵌套”,但可以通过元素结构模拟复杂数据。以下是…

    2025年12月17日
    000
  • XML中如何解析属性列表_XML解析属性列表的操作步骤

    首先选择合适的XML解析方式,如DOM、SAX或高级API;接着定位目标元素,通过attrib或getAttribute方法提取属性;最后处理缺失值与空值,结合异常捕获提升健壮性。 在处理XML文档时,解析属性列表是常见需求。属性通常出现在开始标签中,以“名称=值”的形式提供附加信息。要正确提取这些…

    2025年12月17日
    000
  • XML与配置文件格式对比?如INI、YAML。

    XML适合复杂数据和企业级应用,但冗长;INI简单直观,适用于基础配置;YAML可读性好、结构灵活,适合现代开发,三者依需求选择。 XML、INI 和 YAML 都是常见的配置文件格式,各有特点,适用于不同场景。选择哪种格式主要取决于可读性、结构复杂度、解析难度和使用环境。 1. XML:结构严谨,…

    2025年12月17日
    000
  • XML配置文件如何设计?常见应用场景?

    设计XML配置文件需遵循语义化命名、合理使用属性与子元素、支持注释和Schema验证等原则,适用于Spring框架、Tomcat配置、Maven构建、Logback日志等场景,强调结构清晰、可扩展性和可维护性,尤其在企业级应用中仍具优势。 XML配置文件的设计核心在于结构清晰、可读性强、易于扩展。它…

    2025年12月17日
    000
  • XML在机器人控制中的应用

    XML在机器人控制中用于描述物理结构、任务序列和系统通信,其结构化、可扩展和自描述特性提升了开发效率与系统可靠性。 XML在机器人控制中扮演着不可或缺的角色,它主要被用来定义机器人的物理结构、运动学参数、传感器配置、任务序列以及系统模块间的通信协议,其结构化、可扩展且人机友好的特性,极大地简化了复杂…

    2025年12月17日
    000
  • XML中如何解析嵌套属性节点_XML解析嵌套属性节点的方法与技巧

    首先区分XML中属性与嵌套节点:属性是标签内的键值对,嵌套节点为子元素。使用DOM解析器可逐层访问,如Python的ElementTree通过get()获取属性、find()定位子节点。结合XPath(如lxml库)能高效查询特定节点与属性,支持条件筛选。处理深层嵌套时建议递归或封装函数,安全访问需…

    2025年12月17日
    000
  • XML中如何解析XML配置参数_XML解析XML配置参数的步骤与技巧

    掌握XML解析需选对方式:DOM适合小文件频繁查询,SAX适用于大文件低内存场景,Pull解析则用于Android平台;基本步骤包括加载文档、获取根节点、遍历子节点并提取值;注意处理命名空间、空值判断与异常捕获,可缓存结果提升性能;建议封装工具类支持按标签或属性提取、提供默认值及映射为键值对,以提升…

    2025年12月17日
    000
  • XML与区块链结合应用

    XML与区块链结合,通过XML的结构化与Schema规范提升链上数据的标准化、可验证性及互操作性。利用XSD定义数据模型,将业务数据封装为XML并生成哈希锚定至区块链,实现数据完整性验证;结合离链存储解决效率问题,智能合约与预言机协同解析关键字段触发业务逻辑。该模式在供应链溯源中构建可信事件日志,在…

    2025年12月17日
    000
  • XML在能源行业数据交换中应用

    XML凭借自描述性、可扩展性和模式验证能力,成为能源行业数据交换的基石,支撑智能电网与能源市场的互操作性。 XML在能源行业数据交换中扮演着核心角色,它提供了一种结构化、可扩展且自描述的数据表示方式,极大地提升了不同系统、设备和参与者之间的数据互操作性与集成效率。尤其在能源这种数据量庞大、格式多样且…

    2025年12月17日
    000
  • 什么是FIXML?金融交易标准

    FIXML是FIX协议的XML表示形式,用于非实时、批量和系统间数据交换;相比FIX协议的高效实时性,FIXML强调结构化与可读性,适用于交易后处理、监管报送和数据审计等场景;二者互补,FIX负责前台实时通信,FIXML支撑后台数据管理。 FIXML,全称Financial Information …

    2025年12月17日
    000
  • XML如何支持国际化?

    XML通过全面支持Unicode、结构化数据和内容与表现分离,成为国际化应用的理想选择,其核心优势在于统一编码、语义化标签、灵活的多语言管理及与XSLT等技术结合实现动态语言切换,同时遵循UTF-8编码、资源外化、xml:lang使用和与CAT工具集成等最佳实践可有效应对实际挑战。 XML在国际化(…

    好文分享 2025年12月17日
    000
  • XML与INI文件如何选择?

    选择取决于数据复杂度和使用场景:若为简单键值对配置且需人工易编辑,选INI;若需表达复杂层级结构、数据验证或跨系统交换,选XML。INI适合扁平配置如用户设置,XML适用于复杂数据如商品信息及跨平台通信。当配置极简或追求性能时,可选JSON、YAML或TOML等更现代格式。 在选择XML还是INI文…

    好文分享 2025年12月17日
    000
  • XPath如何选择属性?

    XPath选择属性的核心是使用“@”符号,如//img/@src可提取所有图片链接;通过@选择所有属性,用contains()、starts-with()等函数实现模糊匹配,结合逻辑运算符可构建复杂条件。常见误区包括大小写敏感、命名空间问题、混淆文本与属性值,以及忽略动态加载内容。高效使用时应以稳定…

    2025年12月17日 好文分享
    000
  • XSLT如何国际化输出?

    XSLT国际化核心是解耦文本与格式,通过外部消息文件和locale参数实现多语言输出。使用xsl:key和document()高效查找文本,XSLT 2.0+支持format-date()和format-number()进行地域敏感数据格式化,1.0版本需依赖外部处理或条件逻辑。 XSLT在国际化输…

    2025年12月17日
    000
  • XML如何表示层次关系?

    XML通过标签嵌套形成树状层次结构,以根元素包含子元素的方式表达数据间的父子与兄弟关系,并利用属性提供元数据,从而实现语义清晰、可验证、易查询的数据组织。 XML通过其独特的标签嵌套机制,构建出一种直观且强大的树状结构来表示数据间的层次关系。简单来说,一个XML文档总会有一个根元素(root ele…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信