柯里化的理解和应用

◼ 柯里化也是属于函数式编程里面一个非常重要的概念。

    是一种关于函数的高阶技术;
    它不仅被用于JavaScript,还被用于其他编程语言;

◼ 我们先来看一下维基百科的解释:

    在计算机科学中,柯里化(英语:Currying),又译为卡瑞化或加里化;
    是把接收多个参数的函数,变成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数,而且返回结果的新函数的技术;
    柯里化声称“如果你固定某些参数,你将得到接受余下参数的一个函数”;

◼ 维基百科的解释非常的抽象,我们这里做一个总结:

    只传递给函数一部分参数来调用它,让它返回一个函数去处理剩余的参数;
    这个过程就称之为柯里化;
◼ 柯里化是一种函数的转换,将一个函数从可调用的f(a, b, c) 转换为可调用的f(a)(b)(c)。
    柯里化不会调用函数。它只是对函数进行转换。
案例:
// 普通函数
function foo (x,y,z){
    
} 
foo(10,20,30)
// 柯里化函数
function foo1(x){
   return function foo2(y){
        return function foo3(z){
            return x+y+z
        }
    }
}
foo1(10)(20)(30)
// 柯里化箭头函数
var add3 = x=>y=>z=>x+y+z
console.log(add3(10)(20)(30))

柯里化优势一-函数的职责单一

◼ 那么为什么需要有柯里化呢?
    在函数式编程中,我们其实往往希望一个函数处理的问题尽可能的单一,而不是将一大堆的处理过程交给一个函数来处理;
    那么我们是否就可以将每次传入的参数在单一的函数中进行处理,处理完后在下一个函数中再使用处理后的结果;
◼ 比如上面的案例我们进行一个修改:传入的函数需要分别被进行如下处理
    第一个参数+ 2
    第二个参数* 2
    第三个参数** 2
案例:
    var add = x =>{
    x += 2
      return y => {
       y *=2
         return z =>{
            z = z ** 2
                return x+y+z
        }
    }
} 
console.log(add(1)(2)(3))//16

柯里化优势二-函数的参数复用

◼ 另外一个使用柯里化的场景是可以帮助我们可以复用参数逻辑:
  makeAdder函数要求我们传入一个num(并且如果我们需要的话,可以在这里对num进行一些修改);
  在之后使用返回的函数时,我们不需要再继续传入num了;
  function makeAdder(num){
    return function(count){
      return num + count
    }
  }
  var add5 = makeAdder(5)
  add5(10)//15
  var add10 = makeAdder(10)
  add10(10)//20
posted @   韩德才  阅读(22)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
点击右上角即可分享
微信分享提示