博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript函数式编程之记忆(memorize)
阅读量:6691 次
发布时间:2019-06-25

本文共 641 字,大约阅读时间需要 2 分钟。

  hot3.png

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

你可能感兴趣的文章
修改grub2安装双系统的windows引导
查看>>
zabbix 自定义邮件报警
查看>>
DNS服务器原理及架设
查看>>
我的友情链接
查看>>
剑指offer:矩阵中的路径
查看>>
数据库
查看>>
五步搞定Android开发环境部署——非常详细的Android开发环境搭建教程
查看>>
H.264视频开发技术
查看>>
Java学习笔记—第十一章 多线程机制
查看>>
Ext.MessageBox消息框
查看>>
网络排查常用命令
查看>>
C#设计模式系列:桥接模式(Bridge)
查看>>
Web性能优化:图片优化
查看>>
查看linux版本内核 Linux内核版本的变化
查看>>
Form personization(Form 个性化)报无权限
查看>>
使用xshell打开centos中文显示为乱码
查看>>
达内实习——数据库编程、文件读写数据
查看>>
zabbix 监控percona
查看>>
我的友情链接
查看>>
HA高可用集群基础概念和原理
查看>>