zoukankan      html  css  js  c++  java
  • NodeJs的async

    async.auto最强大的一个api,它适合逻辑复杂的代码,代码中你一部分需要串行,两部分相互依赖,一部分又需要并行,代码中不需要依赖,这个时候你就可以通过auto随性所欲控制你的代码逻辑。

    var async = require('async');
      async.auto({
            //func1、func2是并行执行
            func1: function (callback) {
                 console.log('in func1');
                callback(null, 'data', 'converted to array');
            },
    
            func2: function (callback) {
                 console.log('in func2');
                callback(null, { "puncha": "during" });
            },
            func3: ["func2", function (results, callback) {
                //func2执行完后才执行func3
               console.log('in func3', JSON.stringify(results));
                callback(null, '3');
            }],
            func4: ["func1", "func3", function (results, callback) {
                  //func1,func3执行完后才执行func4
                 console.log('in func4', JSON.stringify(results));
              callback(null, {'file':results.func3, 'email':'user@example.com'});
            }]
        }, function (err, results) {
            //最后返回func1、2、3、4结果
            console.log('err = ', err);
            console.log('results = ', results);
        });

    返回值

    in func1
    in func2
    in func3 {"func1":["data","converted to array"],"func2":{"puncha":"during"}}
    in func4 {"func1":["data","converted to array"],"func2":{"puncha":"during"},"func3":"3"}
    err =  null
    results =  { func1: [ 'data', 'converted to array' ],
      func2: { puncha: 'during' },
      func3: '3',
      func4: { file: '3', email: 'user@example.com' } }

    async.waterfall、async.series 串行 
    async.waterfall 
    按顺序依次执行多个函数。每一个函数产生的值,都将传给下一个函数。如果中途出错,后面的函数将不会被执行。错误信息以及之前产生的结果,将传给waterfall最终的callback

    async.series 
    按顺序依次执行多个函数。前后无依赖。如果中途出错,后面的函数将不会被执行。错误信息以及之前产生的结果,将传给waterfall最终的callback

    async.parallel

    parallel 的原理是同时并行处理每一个流程,最后汇总结果,如果某一个流程出错就退出.他们之间是并行无依赖

  • 相关阅读:
    【react】---react中使用装饰器
    【react】---react中key值的作用
    【react】---react项目中如何使用iconfont
    【react】---redux-actions的基本使用---【巷子】
    linux查看硬件配置
    ssh实现内网穿透
    base_convert()函数探秘及小bug记录
    【转】ASCII码表
    【转载】在C语言中,double、long、unsigned、int、char类型数据所占字节数
    xdebug及phpstorm、vim+dbgpy远程调试配置以及xdebug profile+webgrind笔记
  • 原文地址:https://www.cnblogs.com/yiyi17/p/8466962.html
Copyright © 2011-2022 走看看