JavaScript里的柯里化与反柯里化是什么意思

本文主要介绍"JavaScript里的柯里化与反柯里化是什么意思",希望能够解决您遇到有关问题,下面我们一起来看这篇 "JavaScript里的柯里化与反柯里化是什么意思" 文章。

我们先来简单了解一下他们的作用。

  柯里化又称部分求值,字面意思就是不会立刻求值,而是到了需要的时候再去求值。如果看的懵逼,没事,看完整篇文章再回过头来看这里你就会豁然开朗。

  反柯里化的作用是,当我们调用某个方法,不用考虑这个对象在被设计时,是否拥有这个方法,只要这个方法适用于它,我们就可以对这个对象使用它。

  柯里化(curring)

  我们有这样一个场景,记录程序员一个月的加班总时间,那么好,我们首先要做的是记录程序员每天加班的时间,然后把一个月中每天的加班的时间相加,就得到了一个月的加班总时间。

  但问题来了,我们有很多种方法可以实现它,比如最简单的:

  varmonthTime=0;functionovertime(time){returnmonthTime+=time;}overtime(3.5);//第一天overtime(4.5);//第二天overtime(2.1);//第三天//...console.log(monthTime);//10.1

  每次传入加班时间都进行累加,这样当然没问题,但你知道,如果数据量很大的情况下,这样会大大牺牲性能。

那怎么办?这就是柯里化要解决的问题。

  其实我们不必每天都计算加班时间,只需要保存好每天的加班时间,在月底时计算这个月总共的加班时间,所以,其实只需要在月底计算一次就行。

  2011年JavaScript之父BrendanEich发表了一篇Twitter,提出了反柯里化这个思想,下面这段代码是反柯里化的实现方式之一:

  Function.prototype.uncurring=function(){varself=this;returnfunction(){varobj=Array.prototype.shift.call(arguments);returnself.apply(obj,arguments);};};

  我们先来看看上面这段代码有什么作用。

  我们要把Array.prototype.push方法转换成一个通用的push函数,只需要这样做:

  varpush=Array.prototype.push.uncurring();//测试一下(function(){push(arguments,4);console.log(arguments);//[1,2,3,4]})(1,2,3)

  arguments本来是没有push方法的,通常,我们都需要用Array.prototype.push.call来实现push方法,但现在,直接调用push函数,既简洁又意图明了。

关于 "JavaScript里的柯里化与反柯里化是什么意思" 就介绍到这。希望大家多多支持编程宝库

本文主要介绍"JavaScript中修饰符的作用是什么",希望能够解决您遇到有关问题,下面我们一起来看这篇 "JavaScript中修饰符的作用是什么" 文章。什么是修饰符?  用最简单的形式来说, ...