webpack源码分析——makeCacheable函数和weakMap的缓存应用场景

本文主要是介绍webpack源码分析——makeCacheable函数和weakMap的缓存应用场景,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、makeCacheable 函数

函数功能

该函数是将一个不带缓存的函数 realFn 转换成一个带缓存的版本。这样可以提高性能,因为相同的输入值不需要每次都重新计算,而是可以从缓存中直接获取结果。

二、函数分析

  1. 使用 WeakMap 弱引用特性创建缓存

const cache = new WeakMap();

  1. getCache 函数
const getCache = associatedObjectForCache => {const entry = cache.get(associatedObjectForCache);if (entry !== undefined) return entry;const map = new Map();cache.set(associatedObjectForCache, map);return map;
};

getCache 函数用于获取或创建与给定对象关联的缓存。如果这个对象已经有了一个缓存映射,它将返回这个映射;否则,它会创建一个新的 Map 对象,将其与对象关联,并返回它。

  1. 缓存化函数
const fn = (str, associatedObjectForCache) => {if (!associatedObjectForCache) return realFn(str);const cache = getCache(associatedObjectForCache);const entry = cache.get(str);if (entry !== undefined) return entry;const result = realFn(str);cache.set(str, result);return result;
};

fn 是一个包装过的函数,它接受一个字符串 str 和一个可选的关联对象 associatedObjectForCache。如果没有提供关联对象,fn 将直接调用 realFn 函数。如果提供了关联对象,fn 将尝试从缓存中获取结果,如果缓存中没有结果,它将调用 realFn 并将结果存储在缓存中。

  1. 绑定缓存
fn.bindCache = associatedObjectForCache => {const cache = getCache(associatedObjectForCache);return str => {const entry = cache.get(str);if (entry !== undefined) return entry;const result = realFn(str);cache.set(str, result);return result;};
};

fn.bindCache 方法允许创建一个新的函数,这个函数总是使用associatedObjectForCache缓存结果。这样可以为特定的对象创建一个专用的缓存函数。

##三、源码

const makeCacheable = realFn => {const cache = new WeakMap();const getCache = associatedObjectForCache => {const entry = cache.get(associatedObjectForCache);if (entry !== undefined) return entry;const map = new Map();cache.set(associatedObjectForCache, map);return map;};const fn = (str, associatedObjectForCache) => {if (!associatedObjectForCache) return realFn(str);const cache = getCache(associatedObjectForCache);const entry = cache.get(str);if (entry !== undefined) return entry;const result = realFn(str);cache.set(str, result);return result;};fn.bindCache = associatedObjectForCache => {const cache = getCache(associatedObjectForCache);return str => {const entry = cache.get(str);if (entry !== undefined) return entry;const result = realFn(str);cache.set(str, result);return result;};};return fn;
};

四 函数用途

makeCacheable 函数可以用于性能优化,特别是在处理重复调用且计算成本较高的函数时。例如,在Web开发中,对于解析URL或处理文件路径等操作,使用缓存可以显著减少重复计算的开销,从而提高应用程序的响应速度和效率。通过将缓存绑定到特定的对象,可以确保缓存的生命周期与对象的生命周期相匹配,这有助于避免内存泄漏问题。

这篇关于webpack源码分析——makeCacheable函数和weakMap的缓存应用场景的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/857705

相关文章

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

github打不开的问题分析及解决

《github打不开的问题分析及解决》:本文主要介绍github打不开的问题分析及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、找到github.com域名解析的ip地址二、找到github.global.ssl.fastly.net网址解析的ip地址三

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析

《Spring组件实例化扩展点之InstantiationAwareBeanPostProcessor使用场景解析》InstantiationAwareBeanPostProcessor是Spring... 目录一、什么是InstantiationAwareBeanPostProcessor?二、核心方法解

Java 枚举的基本使用方法及实际使用场景

《Java枚举的基本使用方法及实际使用场景》枚举是Java中一种特殊的类,用于定义一组固定的常量,枚举类型提供了更好的类型安全性和可读性,适用于需要定义一组有限且固定的值的场景,本文给大家介绍Jav... 目录一、什么是枚举?二、枚举的基本使用方法定义枚举三、实际使用场景代替常量状态机四、更多用法1.实现接

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与

Python使用Tkinter打造一个完整的桌面应用

《Python使用Tkinter打造一个完整的桌面应用》在Python生态中,Tkinter就像一把瑞士军刀,它没有花哨的特效,却能快速搭建出实用的图形界面,作为Python自带的标准库,无需安装即可... 目录一、界面搭建:像搭积木一样组合控件二、菜单系统:给应用装上“控制中枢”三、事件驱动:让界面“活”