zoukankan      html  css  js  c++  java
  • Node.js项目 async函数auto、waterfall、series、parallel、async.forEachSeries

    1. async.auto

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

      //auto 适合复杂逻辑,需要Parallel又需要waterfull
        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);
        });

    2. async.waterfall

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

    async.waterfall([
            function (callback) {
                callback(null, 'one', 'two');
            },
            function (arg1, arg2, callback) {
                // 上面的 arg1就是'one'  arg2 就是  'two'
                callback(null, 'three');
            },
            function (arg1, callback) {
                // arg1就是'three'
                callback(null, 'done');
            }
        ], function (err, result) {
            ///最后得到所有
        });

    3.async.series

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

    async.series([
        function(callback) {
    
            callback(null, 'one');
        },
        function(callback) {
    
            callback(null, 'two');
        }
    ],
    
    function(err, results) {
       //最后结果
    });

    4. async.parallel

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

    async.parallel([
        //并行同时执行
        function(callback) {
            setTimeout(function() {
                callback(null, 'one');
            }, 200);
        },
        function(callback) {
            setTimeout(function() {
                callback(null, 'two');
            }, 100);
        }
    ],
    
    function(err, results) {
        //等上面两个执行完返回结果
    });

    5. async.forEachSeries

    当你有一个集合,你想循环集合,然后对每个集合按照顺序执行相应的方法

    var arr = [{name:'Jack', delay: 200},
                {name:'Mike', delay: 100},
                {name:'Freewind', delay: 300}];
    
    
    
            async.forEachSeries(arr, function(item, callback) {
                setTimeout(function(){
                    callback();
                }, item.delay);
            }, function(err) {
    
            });
  • 相关阅读:
    ExtJs005继承
    ExtJs004define定义类
    ExtJS笔记
    解决vscode-pandoc插件生成pdf中文显示问题
    UDP学习笔记(.NET)
    WPF类库不能添加资源词典(xaml)的解决办法
    解决win10下获取操作系统版本为6.2.900(win8)的问题
    [转] Unit Test 访问Internal类型和方法
    VS2017使用小技巧(持续更新。。。)
    [转]Github遇到Permanently added the RSA host key for IP address '192.30.252.128' to the list of known host
  • 原文地址:https://www.cnblogs.com/wrbxdj/p/13986948.html
Copyright © 2011-2022 走看看