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 的原理是同时并行处理每一个流程,最后汇总结果,如果某一个流程出错就退出.他们之间是并行无依赖

posted @   地铁程序员  阅读(170)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示