函数式编程概念之Currying和Partial application

栏目: 编程语言 · 发布时间: 7年前

内容简介:函数式编程概念之Currying和Partial application
function curry(fn){  
    return function curried(...args){
        return args.length >= fn.length ?
            fn.call(this, ...args) :
            (...rest) => {
                return curried.call(this, ...args, ...rest);
            };
    };
}

Curryingis the process of taking a function that accepts N arguments and turning it into a chained series of N functions each taking 1 argument.

柯里化是一个将一个接受N个参数的函数转化为一系列N个接受一个参数的函数的过程。

let curryAdd = curry(add);
curryAdd(1);

上面的结果是:

(...rest) => {
  return curried.call(this, ...args, ...rest);
}

说明参数不够时返回的是一个函数,这个函数等待接受后面的函数,最终当参数数量足够时执行函数:

curryAdd(1)(2)(3);			// 6

看一张图:

函数式编程概念之Currying和Partial application

Partial Application

Partial applicationmeans taking a function and paritally applying it to one or more of its arguments, but not all, creating a new function in the process.

偏函数应用意思是使用一个或多个参数来部份化应用一个函数,而非全部,在这个过程会生成新的函数。

它的代码比较简单:

function apply(fn, ...args){  
    return (..._args) => {
        return fn(...args, ..._args);
    };
}

执行的话:

apply(add, 1, 2, 3)  	// 6
apply(add, 1, 2)		// ?

上面的第二个执行结果是:

(...args) => {
  return fn(...args, ..._args);
}

它们的区别也很容易发现了:

let applyAdd = apply(add);
applyAdd(1, 2, 3)		// 6
applyAdd(1)(2)(3)		// Error

Partial application 并不是currying,它不能接受一个函数,然后执行返回一个函数,但他可以接受一个函数和部分参数,执行来返回一个函数:

let applyAdd1 = apply(add, 1);
applyAdd1(2,3)			// 6
applyAdd1(2)			// NaN

你可以看到应用不等于执行,因为它不像currying,不会在参数不足时返回一个可以执行声明闭包的函数,它只会发现参数不足,执行错误,但apply函数不同,它是返回函数的,所以执行是安全的。

所以说currying是转化(turn),而partial application是创造(create),它们有着不同的使用场景


以上所述就是小编给大家介绍的《函数式编程概念之Currying和Partial application》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据结构

数据结构

霍罗威茨 / 机械工业出版社 / 2006-7-1 / 48.00元

《数据结构》(C语言版)针对采用ANSI C实现数据结构进行了全面的描述和深入的讨论。书中详细讨论了栈、队列、链表以及查找结构、高级树结构等功能,对裴波那契堆、伸展树、红黑树、2-3树、2-3-4树、二项堆、最小-最大堆、双端堆等新的数据结构进行了有效分析。《数据结构》(C语言版)对一些特殊形式的堆结构,诸如应用在双端优先队列中的最小-最大堆和双端堆的数据结构以及左高树、裴波那契堆、二项堆等数据结......一起来看看 《数据结构》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器