zoukankan      html  css  js  c++  java
  • [Javascript] Understand Curry

    The act of currying can be described as taking a multivariate function and turning it into a series of unary functions.

    Let's see an example:

    const add = a => b=> a + b;
    const inc = add(1);
    
    const res = inc(3) // 4

    This is a very basic currying example. 

    We wrote a function 'add' take a param 'a' return a function which take param 'b', finally return a + b;

    We can based on 'add' function to create another function 'inc'. This approach is good for resuability. But there is one problem, because you cannot do:

    add(1,3)

    To solve the problem we need to write a 'curry' function, the basic idea is:

    1. Check the passed in function, how many params it should takes, in our case 'add' function take 2 params.

    2. 'curry' should return another function, inside function it should check, if length of params is the same as function's params, in our case is:

    add(1,3)

    Then we invoke function immediately. (Using .call for immediately invoke) 

    3. Otherwise, we should still return a function with param partially applyied. (using .bind for partially apply)

    function curry(fn) {
      // The number of fn's params
      // fn = (a, b) => a + b
      // then length is 2
      const arity = fn.length;
      console.log(arity)
      return function $curry(...args) {
        console.log(args, args.length)
        if (args.length < arity) {
          // partially apply
          // in case of add(1)(2)
          return $curry.bind(null, ...args);
        }
        // immediately invoke
        // in case of add(1,2)
        return fn.call(null, ...args);
      };
    };
    
    const add = curry((a, b) => a + b);
    const inc = add(1);
    const res = inc(2) // 3

    Arity describes the number of arguments a function receives. Depending on the number it receives, there are specific words to describe these functions.

    A function that receives one is called a unary function.

    A function that receives two arguments is called a binary,

    three equals a ternary,

    and four equals a quaternary,

    so forth and so on.

  • 相关阅读:
    CentOS5.5环境下布署LVS+keepalived
    CentOS 6.3下部署LVS(NAT)+keepalived实现高性能高可用负载均衡
    Redis的事务
    Redis_持久化之RDB
    Redis有序集合Zset(sorted set)
    Redis哈希-hash
    Redis集合-Set
    Redis 数据类型-List
    Java多线程与并发库高级应用-同步集合
    Java多线程与并发库高级应用-可阻塞的队列
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10514147.html
Copyright © 2011-2022 走看看