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

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

WBOY
发布: 2024-08-28 06:08:06
原创
520 人浏览过

Prevents re-execution of large javascript functions that have been processed once with the same parameter.

记忆法

使用相同参数执行的函数的缓存机制(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
登录后复制

绩效结果

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

Case ms
First execute time (no caching) > 52.08 ms
Second execute time (caching) < 0.03 ms
and subsequent execution (caching) < 0.03 ms

测试覆盖率结果

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

File % Stmts % Branch % Funcs % Lines Uncovered Line #s
All files 100 100 100 100 0
lib 100 100 100 100 0
index.ts 100 100 100 100 0
lib/store 100 100 100 100 0
CacheStore.ts 100 100 100 100 0
DepsStore.ts 100 100 100 100 0

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

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板