24-函数缓存以及应用场景

这篇具有很好参考价值的文章主要介绍了24-函数缓存以及应用场景。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、是什么

函数缓存,就是将函数运算过的结果进行缓存

本质上就是用空间(缓存存储)换时间(计算过程)。


常用于缓存数据计算结果和缓存对象

const add = (a,b)=> a+b;
const calc = memoize(add);// 函数缓存
calc(1,2)

缓存只是一个临时的数据存储,它保存数据,以便将来对该数据的请求能够更快地得到处理

二、如何实现

实现函数缓存主要依靠闭包、柯里化、高阶函数

闭包

闭包可以理解成,函数 + 函数体内可访问的变量总和

(function(){
 var a = 1;
 function add(){
 	const b = 2;
 	let sum = b + a
 	console.log(sum);
 }
 add()
})()

add函数本身,以及其内部可访问的变量,即 a = 1,这两个组合在⼀起就形成了闭包

柯里化

把接收多个参数的函数转换成接收单一参数的函数

// 非柯里化
var add = function (x,y){
	return x+y;
}
add(3,1)
// 柯里化
var add2 = function (x){
	// 返回函数
	return function (y){
		return x + y
	}
}
add2(3)(1)

高阶函数

通过接收其他函数作为参数或返回其他函数的函数

function foo(){
	var a = 2;
	function bar(){
		console.log(a);
	}
	return bar;
}
var baz = foo();
baz();

三、应用场景

虽然使用缓存效率是非常高的,但并不是所有场景都适用,因此千万不要极端的将所有函数都添加缓存

以下几种情况下,适合使用缓存文章来源地址https://www.toymoban.com/news/detail-525885.html

  • 对于昂贵的函数调用,执行复杂计算的函数
  • 对于具有有限且高度重复输入范围的函数
  • 对于具有重复输入值的递归函数
  • 对于纯函数,即每次使用特定输入调用时返回相同输出的函数

到了这里,关于24-函数缓存以及应用场景的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包