javascript - NodeJS, Async forEachSeries execution order - Stack Overflow

Just trying to get my head around using Async module for NodeJS.I have the following code.var a1 = [1,2

Just trying to get my head around using Async module for NodeJS.

I have the following code.

var a1 = [1,2,3,4,5,6,7,8];
async.forEachSeries(a1, function(n1, callback) {
    console.log(n1);
    var a2 = [10,11,12,13,14];
    async.forEachSeries(a2, function(n2, callback) {
        console.log(n1 + " " + n2);
        callback();
    });
    callback();
});

I want to make the process of the above code in such a way that the print out becomes

1
1 10
1 11
1 12
1 13
1 14
2
2 10
2 11
2 12
2 13
2 14
3
3 10
3 11
3 12
3 13
3 14
.....

But instead I'm getting something like..

1
1 10
2
2 10
1 11
3
3 10
2 11
1 12
....

How do I fix this?

Just trying to get my head around using Async module for NodeJS.

I have the following code.

var a1 = [1,2,3,4,5,6,7,8];
async.forEachSeries(a1, function(n1, callback) {
    console.log(n1);
    var a2 = [10,11,12,13,14];
    async.forEachSeries(a2, function(n2, callback) {
        console.log(n1 + " " + n2);
        callback();
    });
    callback();
});

I want to make the process of the above code in such a way that the print out becomes

1
1 10
1 11
1 12
1 13
1 14
2
2 10
2 11
2 12
2 13
2 14
3
3 10
3 11
3 12
3 13
3 14
.....

But instead I'm getting something like..

1
1 10
2
2 10
1 11
3
3 10
2 11
1 12
....

How do I fix this?

Share Improve this question edited Aug 4, 2013 at 12:07 Bergi 665k161 gold badges1k silver badges1.5k bronze badges asked Apr 11, 2013 at 7:18 ericbaeericbae 9,64426 gold badges77 silver badges109 bronze badges 7
  • 2 If you need synchronous output, why do you perform it async? – NilsH Commented Apr 11, 2013 at 7:22
  • 1 hm. doesn't forEachSeries perform in a synchronous way? – ericbae Commented Apr 11, 2013 at 7:26
  • Both Node 0.10.3 and 0.8.16 produce the output you want on my Mac. Are you piping the output of the script to a file (or another program)? That changes the behaviour of process.stdout, and therefore console.log as well, so that might result in different output. And forEachSeries is synchronous in that the next iteration will only be called once the previous is done. – robertklep Commented Apr 11, 2013 at 7:44
  • Hm.. you're right. On my machine it does in fact produce the output you expected as well. But I would rather call it "in sequence" than "synchronous". I'm using node 0.10.3 btw. – NilsH Commented Apr 11, 2013 at 7:45
  • @NilsH I guess it's a matter of semantics :) I'd call it synchronized since the operations are dependent on each other, (N+1) only gets called once (N) has completed. – robertklep Commented Apr 11, 2013 at 8:30
 |  Show 2 more comments

1 Answer 1

Reset to default 17

The forEachMethod also accepts a callback when everything done. So your code should look like this:

var a1 = [1,2,3,4,5,6,7,8];
async.forEachSeries(a1, function(n1, callback_s1) {
    console.log(n1);
    var a2 = [10,11,12,13,14];
    async.forEachSeries(a2, function(n2, callback_s2) {
        console.log(n1 + " " + n2);
        callback_s2();
    }, function () {
        /* Finished the second series, now we mark the iteration of first series done */ 
        callback_s1();
    } );
});

The problem in your code is the fact that you assume async.forEachSeries to be synchronous, but it is not. It guarantees the fact the array will be handled synchronously, but the function itself is asynchronous.

发布者:admin,转转请注明出处:http://www.yc00.com/questions/1739410367a4126191.html

相关推荐

发表回复

评论列表(0条)

  • 暂无评论

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信