javascript中执行函数的顺序

时间:2016-03-03 07:40:44

标签: javascript node.js

在研究node.js时,我遇到了一个产生奇怪结果的例子。这是代码:

/* 01 */  var zlib = require("zlib");
/* 02 */  var input = '...............text...............';
/* 03 */  zlib.deflate(input, function(err, buffer) {
/* 04 */    if (!err) {
/* 05 */      console.log("deflate (%s): ", buffer.length,buffer.toString('base64'));
/* 06 */      zlib.inflate(buffer, function(err, buffer) {
/* 07 */        if (!err) {
/* 08 */          console.log("inflate (%s): ", buffer.length, buffer.toString());
/* 09 */        }
/* 10 */      });
/* 11 */      zlib.unzip(buffer, function(err, buffer) {
/* 12 */        if (!err) {
/* 13 */          console.log("unzip deflate (%s): ", buffer.length, buffer.toString());
/* 14 */        }
/* 15 */      });
/* 16 */    }
/* 17 */  });
/* 18 */ 
/* 19 */  zlib.deflateRaw(input, function(err, buffer) {
/* 20 */    if (!err) {
/* 21 */      console.log("deflateRaw (%s): ", buffer.length, buffer.toString('base64'));
/* 22 */      zlib.inflateRaw(buffer, function(err, buffer) {
/* 23 */        if (!err) {
/* 24 */          console.log("inflateRaw (%s): ", buffer.length, buffer.toString());
/* 25 */        }
/* 26 */      });
/* 27 */    }
/* 28 */  });
/* 29 */ 
/* 30 */  zlib.gzip(input, function(err, buffer) {
/* 31 */    if (!err) {
/* 32 */      console.log("gzip (%s): ", buffer.length, buffer.toString('base64'));
/* 33 */      zlib.gunzip(buffer, function(err, buffer) {
/* 34 */        if (!err) {
/* 35 */          console.log("gunzip (%s): ", buffer.length, buffer.toString());
/* 36 */        }
/* 37 */      });
/* 38 */      zlib.unzip(buffer, function(err, buffer) {
/* 39 */        if (!err) {
/* 40 */          console.log("unzip gzip (%s): ", buffer.length, buffer.toString());
/* 41 */        }
/* 42 */      });
/* 43 */    }
/* 44 */  });

我希望会产生以下结果:

deflate (18) : ...some thing strange !... 
inflate (34) :............text.............
unzip deflate (34) :............text.............
deflateRaw (12) :...some thing strange !... 
inflateRaw34() :............text.............
gzip (30) :...some thing strange !... 
gunzip(34) :............text.............
unzip gzip (34) :............text.............

但我遇到了这个:

actual execution order

那么如果函数的执行顺序不符合它们的顺序,那么它们的执行顺序是什么?

0 个答案:

没有答案