Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/325.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Node.js 在async.series中调用async.series会产生不可预测的输出_Node.js - Fatal编程技术网

Node.js 在async.series中调用async.series会产生不可预测的输出

Node.js 在async.series中调用async.series会产生不可预测的输出,node.js,Node.js,使用caolan的node.js异步库,我尝试在另一个使用async.series的函数中调用一个使用async.series的函数,但我仍然无法让函数以正确的顺序运行,如下所述: 终端输出显示在第一个函数之前调用的第二个函数,没有明显的原因: The "sys" module is now called "util". It should have a similar interface. Starting the second step in the series Value of b: u

使用caolan的node.js异步库,我尝试在另一个使用async.series的函数中调用一个使用
async.series
的函数,但我仍然无法让函数以正确的顺序运行,如下所述:

终端输出显示在第一个函数之前调用的第二个函数,没有明显的原因:

The "sys" module is now called "util". It should have a similar interface.
Starting the second step in the series
Value of b: undefined
Invoking the function firstStep
the value of toObtain is: [object Object]
下面是相应的源代码:

var im = require('imagemagick');
var async = require('async');

var toObtain;


var b;
async.series([

function (callback) {
    //It appears that this function is being invoked after the second function.
    //Why is this happening?
    firstStep();
    callback();
},

function (callback) {
    //Why is the output of this function being displayed BEFORE the output of the function above? It's the opposite of the order in which I'm calling the functions.
    console.log("Starting the second step in the series");
    console.log("Value of b: " + b);
}]);


function firstStep(){
    async.series([

    function (next) { // step one - call the function that sets toObtain
        im.identify('kittens.png', function (err, features) {
            if (err) throw err;
            console.log("Invoking the function firstStep");
            toObtain = features;
            //console.log(toObtain);
            b = toObtain.height;
            next(); // invoke the callback provided by async
        });
    },

    function (next) { // step two - display it
        console.log('the value of toObtain is: %s',toObtain.toString());
    }]);
}

经过大约一个小时的实验,我让它正常工作。我只是修改了firstStep函数,使其将回调函数作为参数,并在firstStep函数末尾调用回调函数

var im = require('imagemagick');
var async = require('async');

var toObtain = false;


var b;
async.series([

function (callback) {
    firstStep(callback); //the firstStep function takes a callback parameter and calls the callback when it finishes running. Now everything seems to be working as intended.
},

function (callback) {
    console.log("Starting the second step in the series");
    console.log("Value of b: " + b);
}]);


function firstStep(theCallback){
    async.series([

    function (next) { // step one - call the function that sets toObtain
        im.identify('kittens.png', function (err, features) {
            if (err) throw err;
            console.log("Invoking the function firstStep");
            toObtain = features;
            //console.log(toObtain);
            b = toObtain.height;
            next(); // invoke the callback provided by async
        });
    },

    function (next) { // step two - display it
        console.log('the value of toObtain is: %s',toObtain.toString());
        theCallback();
    }]);
}