zoukankan      html  css  js  c++  java
  • compose函数和pipe函数

    compose函数

    compose函数可以将需要嵌套执行的函数平铺,嵌套执行就是一个函数的返回值将作为另一个函数的参数。我们考虑一个简单的需求:

    给定一个输入值x,先给这个值加10,然后结果乘以10
    

    这个需求很简单,直接一个计算函数就行:

    const calculate = x => (x + 10) * 10;
    let res = calculate(10);
    console.log(res);    // 200
    

    但是根据我们之前讲的函数式编程,我们可以将复杂的几个步骤拆成几个简单的可复用的简单步骤,于是我们拆出了一个加法函数和一个乘法函数:

    const add = x => x + 10;
    const multiply = x => x * 10;
    
    // 我们的计算改为两个函数的嵌套计算,add函数的返回值作为multiply函数的参数
    let res = multiply(add(10));
    console.log(res);    // 结果还是200
    

    上面的计算方法就是函数的嵌套执行,而我们compose的作用就是将嵌套执行的方法作为参数平铺,嵌套执行的时候,里面的方法也就是右边的方法最开始执行,然后往左边返回,我们的compose方法也是从右边的参数开始执行,所以我们的目标就很明确了,我们需要一个像这样的compose方法:

    // 参数从右往左执行,所以multiply在前,add在后
    let res = compose(multiply, add)(10);
    

    那这个compose方法要怎么实现呢,这里需要借助Array.prototype.reduce,这个方法会从左往右迭代,但是我们需要的是从右往左迭代,这个方法是Array.prototype.reduceRight:

    const compose = function(){
      // 将接收的参数存到一个数组, args == [multiply, add]
      const args = [].slice.apply(arguments);
      return function(x) {
        return args.reduceRight((res, cb) => cb(res), x);
      }
    }
    
    // 我们来验证下这个方法
    let calculate = compose(multiply, add);
    let res = calculate(10);
    console.log(res);    // 结果还是200
    

    上面的compose函数使用ES6的话会更加简洁:

    const compose = (...args) => x => args.reduceRight((res, cb) => cb(res), x);
    

    Redux的中间件就是用compose实现的,webpack中loader的加载顺序也是从右往左,这是因为他也是compose实现的。

    pipe函数

    pipe函数跟compose函数的左右是一样的,也是将参数平铺,只不过他的顺序是从左往右。我们来实现下,只需要将reduceRight改成reduce就行了:

    const pipe = function(){
      const args = [].slice.apply(arguments);
      return function(x) {
        return args.reduce((res, cb) => cb(res), x);
      }
    }
    
    // 参数顺序改为从左往右
    let calculate = pipe(add, multiply);
    let res = calculate(10);
    console.log(res);    // 结果还是200
    

    ES6写法:

    const pipe = (...args) => x => args.reduce((res, cb) => cb(res), x)
    
  • 相关阅读:
    比特币学习笔记(五)---继续解读入口部分源码
    比特币学习笔记(四)---解读入口部分源码
    比特币学习笔记(三)---配置文件和启动
    比特币学习笔记(二)---在windows下调试比特币源码
    比特币学习笔记(一)---在windows下编译搭建比特币环境
    让我们把KBEngine玩坏吧!如何定制我们自己的C++函数(一)
    KBEngine warring项目源码阅读(三) 实体文件与Account处理
    KBEngine warring项目源码阅读(二) 登录和baseapp的负载均衡
    KBEngine warring项目源码阅读(一) 项目简介和注册
    JMeter测试TCP服务器遇到的一个奇怪问题
  • 原文地址:https://www.cnblogs.com/dennisj/p/12176290.html
Copyright © 2011-2022 走看看