对于async的错误理解

/**
 * Created by qiucheng on 15/8/27.
 */

var async = require("async");


var arr = [1, 2, 3];
var transformed = arr.map(function (ele) {
    return ele * 3;
});

console.log(transformed);

async.map(arr, function (val, callback) {
        setTimeout(function () {
            console.log(val);
            callback(null, val * 2);
        }, 10);
    },
    function (err, results) {
        if (err) {
            console.log(err);
        }
        console.log(results);
    }
);
console.log("end");


上面这段代码中,map和async.map的区别在于,async版本的第二个参数的函数内可以调用异步方法,然后通过callback的方式表示返回值。

也就是说如果第二个参数的函数里没有异步方法的话,map和async版本是一样的。


async.map(arr, function (val, callback) {//该版本和不适用async.map一致
        console.log(val);
        callback(null, val * 2);
    },
    function (err, results) {
        if (err) {
            console.log(err);
        }
        console.log(results);
    }
);

并且,如果说在某些情况下的确不需要使用异步操作时,也不能在第二个函数中直接调用callback函数,不然可能会引起stack overflow,如下图所示:

 
 
async.eachSeries(hugeArray, function iterator(itemcallback) {
  if (inCache(item)) {
    callback(null, cache[item]); // if many items are cached, you'll overflow 
  } else {
    doSomeIO(item, callback);
  }
}, function done() {
  //... 
});


正确做法应该是;

 
 
async.eachSeries(hugeArray, function iterator(itemcallback) {
  if (inCache(item)) {
    async.setImmediate(function () { //让他进入下一次运行队列
      callback(null, cache[item]);
    });
  } else {
    doSomeIO(item, callback);
  //... 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值