函数柯里化
2016-06-16 22:31
274 查看
一、柯里化的概念
百度百科:在计算机科学中,柯里化(Currying)是把接受多个参数的函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数且返回结果的新函数的技术。这个技术以逻辑学家 Haskell Curry 命名的。举例:
//接受多个参数 function add(num1,num2){ return num1+num2; } //curry接受单一参数5 var curriedAdd = currying(add,5); //curry返回接受余下的参数3,且返回结果8的新函数curriedAdd alert(curriedAdd(3)); //8
二、柯里化的具体实现
//currying(add,5) function currying(fn) { var slice = Array.prototype.slice, //从第二个参数开始,所以_args为5 __args = slice.call(arguments, 1); return function () { //curriedAdd(3),所以__inargs为3 var __inargs = slice.call(arguments); return fn.apply(null, __args.concat(__inargs)); }; }
三、柯里化的用途
降低适用范围,但同时降低代码的重复性不使用柯里化:
function square(i) { return i * i; } function map(handeler, list) { return list.map(handeler); } // 重复square map(square, [1, 2, 3, 4, 5]); map(square, [6, 7, 8, 9, 10]); map(square, [10, 20, 30, 40, 50]); // ......
使用柯里化
function square(i) { return i * i; } function map(handeler, list) { return list.map(handeler); } var mapSQ = currying(map, square); mapSQ([1, 2, 3, 4, 5]); mapSQ([6, 7, 8, 9, 10]); mapSQ([10, 20, 30, 40, 50]); // ......
相关文章推荐
- Android中的IPC方式——使用Bundle和文件共享
- 关于C#中的new的用法
- Oracle学习 第8天
- MIT Introduction to Algorithms Record-8
- 物流营销服务
- Android6.0软件崩溃问题
- Android开发用过的十大框架
- mysql源码分析
- PHP Slim 框架初体验之无法访问控制器
- 实现下拉列表更新
- 怎么用程序获取远程url执行后的图片地址
- shell脚本中反引号与$()的区别
- python ssh
- ffmpeg 从视频流中抓取图片
- lamp centos虚拟主机配置
- 如何查找Mac上的USB存储设备使用痕迹
- scala学习手记13 - 类继承
- SQL服务器无法登陆SQL控制台
- 168. Excel Sheet Column Title
- 豆瓣最受欢迎的影评爬虫(第一个爬虫撒花!)