浅谈柯里化以及实现原理

什么是柯里化

在维基百科中,对柯里化的定义是把接受多个参数函数变换成接受一个单一参数(最初函数的第一个参数)的函数,并且返回接受余下的参数而且返回结果的新函数的技术。

柯里化的使用

举一个例子🌰

例如我们需要编写一个求和函数,我们可能会这样写

const getSum = (a, b, c) => {
  return a + b + c;
};

getSum(1,2,3);

我们简单地对这个函数进行柯里化,先利用lodash中的柯里化方法,我们可以这样写

const _ = require("lodash");

const curried = _.curry(getSum);

curried(1)(2)(3);
curried(1, 2)(3);

再举一个例子🌰

我们编写一个匹配函数,查找字符串是否包含数字

// 普通写法
const match = (reg, str) => {
 return str.match(reg);
}

match(/\d+/g, 'nba123')

// 柯里化案例
const curryMath = _.curry(match);
const hasNumber = curryMath(/\d+/g);

hasNumber("nba123")

柯里化是对函数参数的缓存,让函数变得更灵活,粒度更小。

柯里化的实现

我们可以自己实现一下柯里化函数,如下

// 自定义柯里化方法
function myCurried(func) {
  return function carriedFunc(...args) {
    // 判断实参和形参的个数,**func.length** 表示所传入函数的参数个数
    if (args.length < func.length) { 
      return function (...arg1) {
        return carriedFunc(...[...args, ...arg1]);
      };
    }
    return func(...args);
  };
}

// 测试代码
const getSum = (a, b, c) => {
  return a + b + c;
};

const curried = myCurried(getSum);

console.log(curried(1)(2, 3));
console.log(curried(1, 2)(3));
console.log(curried(1, 2, 3));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值