Memoization 是通过缓存“输入→输出”映射来避免重复计算的优化技术,需函数纯、参数可序列化,缓存需手动管理,非 JavaScript 内置但可手写或借助工具实现。

Memoization 是一种优化技术,通过缓存函数的执行结果,避免对相同输入重复计算。 它不是 JavaScript 语言内置的特性,而是开发者可以手动实现或借助工具库(如 Lodash 的 _.memoize)来应用的编程模式。
核心逻辑很简单:当函数被调用时,先检查之前是否用**完全相同的参数**调用过;如果有,直接返回缓存的结果,跳过实际运算。
Map 存储,键是参数的序列化形式(比如 JSON.stringify([a, b])),值是返回结果下面是一个基础但实用的实现:
function memoize(fn) {
const cache = new Map();
return function(...args) {
const key = JSON.stringify(args);
if (cache.has(key)) {
return cache.get(key);
}
const result = fn.apply(this, args);
cache.set(key, result);
return result;
};
}
// 使用示例
const expensiveAdd = memoize((a, b) => {
console.log('计算中...');
return a + b;
});
expensiveAdd(2, 3); // 打印"计算中...",返回5
expensiveAdd(2, 3); // 不打印,直接返回5(命中缓存)
JSON.stringify 可能不适用(比如含函数、undefined、循环引用),此时需更健壮的序列化或改用 Map + 自定义键生成逻辑React 的 useMemo 和 useCallback 借用了 memoization 的思想,但它们的缓存生命周期绑定在组件渲染周期内,只在依赖数组不变时复用上一次值,并非跨多次调用持久保存。它们解决的是渲染性能问题,不是通用函数计算优化。
立即学习“Java免费学习笔记(深入)”;
基本上就这些。它不复杂,但容易忽略参数可序列化性和缓存管理,用对了能明显提升性能,用错了反而引入 bug。
以上就是javascript的memoization是什么_它如何缓存结果?的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号