zoukankan      html  css  js  c++  java
  • curry柯里化函数实现

    curry柯里化函数实现

    参考文章: 一行写出javascript函数式编程中的curry
    感谢作者分享

    第一步: 缓存原始函数的参数个数

    function curry(fn) {
      var limit = fn.length // 缓存参数格式
      // ...
    }
    

    第二步: 判断参数个数, 是不是我们需要的个数

    function curry(fn) {
      var limit = fn.length // 缓存参数格式
      return function (...args) {
        if (args.length >= limit) { /// 如果传入的参数个数等于了, 我们需要的参数个数, 直接返回
          return fn.applay(null, args) // 但是执行的,指针变为null, 就有点不理解了.
        }
      }
    }
    

    第三步: 参数不够, 返回一个存储了参数的函数, 不断调用该函数, 一直到参数传满为止

    function curry(fn) {
      var limit = fn.length // 缓存参数格式
      return function judgeCurry(...args) { // 但参数不够的时候, 需要不断返回这个函数, 将参数依次累加
        if (args.length >= limit) { /// 如果传入的参数个数等于了, 我们需要的参数个数, 直接返回
          return fn.applay(null, args) // 但是执行的,指针变为null, 就有点不理解了. 可能就像下面一样, 仅仅是个占位
        } else {
          return function (...args2) {
            return judgeCurry.apply(null, args.concat(args2)) // 不断调用, 需要返回的函数, 一直到参数够了位置
          }
        }
      }
    }
    
    // 检测
    function add(a, b, c) {
      return a + b + c
    }
    
    var res = curry(add)(1)(2)(3)
    console.log(res) // 6
    

    第四步: 一行写出

    var currySingle = fn => judgeCurry = (...args) => args.length >= fn.length ? fn.apply(null, args) : (...args2) => judgeCurry.apply(null, args.concat(args2))
    

    第五步: 一行写出优化, 立即执行函数, 缓存参数

    var currySingle = fn => ((limit) => judgeCurry = (...args) => args.length >= limit ? fn.apply(null, args) : (...args2) => judgeCurry.apply(null, args.concat(args2)))(fn.length)
    
  • 相关阅读:
    随笔
    随笔
    随笔1
    随笔2
    intellij-maven-imports-have-broken-classpath
    如何使用idea把web项目打成war包
    spring-wind 搭建过程问题记录
    windows 64位 安装mvn提示 不是内部或外部命令
    面试碰到“为何从上家离职”...
    nginx 两台机器 出现退款失败问题
  • 原文地址:https://www.cnblogs.com/zhangrunhao/p/9202789.html
Copyright © 2011-2022 走看看