您的位置:首页 > 其它

函数柯里化

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]);
// ......
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: