JavaScript函数式编程之记忆(memorize)

在浏览器中,一个算法的执行时间往往会成为瓶颈,我们可以将上一次计算的结果缓存起来。在函数式编程当中,这种缓存技巧叫做记忆(memorize):

function memorize( fn ) {

    var cache = {};//保存缓存的对象

    return  function(){

        var key = arguments.length + Array.prototype.join.call( arguments, ","); //产生一个缓存的键: 参数长苏+参数

        if(key in cache) {

            return cache[key];

        }else {

            return cache[key] = f.apply( this, arguments );

        }

    }

}

下面是一个计算两个书最大公约数的例子:

//计算函数

function gcd(a,b) {

        var t;

        if(a<b) {

            t=b; b=a; a=t;    

        }

        while(b != 0) {

            t=b;b=a%b;a=t;

        }

        return a;

}

 

var gcdmemo = memorize(gcd);

gcdmemo(85,187);

 

一个阶乘的求解例子:

var fact = memorize(function(n) {

    return (n<=1) ? 1 : n*fact(n-1);

});

fact(5);

 

转载于:https://my.oschina.net/johny/blog/77242

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值