首页 > web前端 > js教程 > 正文

防止重新执行已使用相同参数处理过一次的大型 JavaScript 函数

WBOY
发布: 2024-08-28 13:58:50
转载
563人浏览过

防止重新执行已使用相同参数处理过一次的大型 javascript 函数

记忆法

使用相同参数执行的函数的缓存机制(memoizer)(仅 1.14 kb)

该项目提供了 memoize 函数,通过缓存昂贵的函数调用结果来提高 javascript 或 typescript 项目的性能。通过记忆,使用相同参数重复调用将返回缓存的结果,从而加快执行速度。

这个模块的工作方式类似于 react 的 usememo hook,但不需要 react。您可以使用任何框架或纯javascript项目

npm 包
github

特征

  • 函数记忆:缓存具有相同参数的函数调用结果。
  • 依赖跟踪:如果依赖关系发生变化,则更新缓存。
  • 灵活性:可用于 javascript 和 typescript 项目。
  • cpu密集型运算或复杂计算的最佳解决方案
  • 断开连接的函数将从内存中删除。属于该函数的缓存也被删除。
  • 基于weakmap的缓存存储
  • weakmap 断开无法与弱引用链接通信的方法,并触发垃圾收集器启动

使用案例

没有 deps 参数

在下面的过程中,当使用相同的参数再次调用 concatphonenumber 方法时,该函数不会再次执行,而是从缓存中获取结果。

import memofy from "memofy";

const concatphonenumber = (extension, number) => {
  // heavy calculation
  // return result
};

const memoizedconcatphonenumber = memofy(concatphonenumber, []);

memoizedconcatphonenumber(90, 555); // runs concatphonenumber when first run
memoizedconcatphonenumber(90, 555); // get value from cache

memoizedconcatphonenumber(90, 552); // runs concatphonenumber because params is change
登录后复制

带 deps 参数

如果你想让方法根据某些依赖关系以相同的参数再次运行,你可以传递 deps 参数,如下所示。

import memofy from "memofy";

const taxRatio = 0.5;
const product = { title: "Test product", price: 10 };

const calculateTax = () => {
  // Calculate tax by product price
  // Heavy calculation
  return taxRatio * product.price;
};

const memoizedConcatPhoneNumber = memofy(calculateTax, [product, taxRatio]);

calculatedPrice = calculateTax(); // Runs concatPhoneNumber when first run

product.price = 40;
let calculatedPrice = calculateTax(); // Runs concatPhoneNumber because product dep changed

taxRatio = 0.8;
calculatedPrice = calculateTax(); // Runs concatPhoneNumber because taxRatio changed
登录后复制

绩效结果

区分素数的复杂函数的性能结果。性能测试

案例 毫秒
首次执行时间(无缓存) > 52.08 毫秒
第二次执行时间(缓存)
以及后续执行(缓存)

测试覆盖率结果

针对所有情况和所有参数类型编写了测试。测试

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

文件 % stmts % 分支 % 功能 % 线路 未覆盖的线路#s
所有文件 100 100 100 100 0
lib 100 100 100 100 0
index.ts 100 100 100 100 0
库/商店 100 100 100 100 0
cachestore.ts 100 100 100 100 0
depsstore.ts 100 100 100 100 0

以上就是防止重新执行已使用相同参数处理过一次的大型 JavaScript 函数的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
相关标签:
来源:dev.to网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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