我必须使用async.parallel或Q.all?怎么样? + NodeJS

时间:2018-08-23 11:24:48

标签: node.js promise async-await q async.js

您好,我有以下代码,我想使用async.parallelQ.all函数来并行执行函数调用。

我是否应该使用,请回复,您的所有答复都是赞赏。

function getPath(x){
    return (x/100);  // It's demo here it's some big logic exist.
}

var array = [4,56,2,3,34,45,65,23,23,12,12,23,34,43,54,54];  // lack of data in array
var resultArr = [];
array.forEach(function(val){
    resultArr.push(getPath(val));
})

// After 5-8 sec, I got results. 

我可以使用async.parellelQ.all如何执行相同的操作吗?

1 个答案:

答案 0 :(得分:1)

Q和Promise可以混合使用,您甚至可以等待与A +兼容的Q Promise。这是一个使用promises的示例,另一个使用async / await

function readDir(x) {
    return new Promise(function(rs){
        setTimeout(rs, x, x)
    })
}

function getPath(x) {
    return readDir(x).then(function(val){
         return val / 100
    })
}

var array = [4,56,2,3,34,45,65,23,23,12,12,23,34,43,54,54];  // lack of data in array
var resultArr = array.map(function(val) {
    return getPath(val);
});

// Q.all is the equivulant of Promise.all
Promise.all(resultArr).then(console.log)

function readDir(x) {
    return new Promise(function(rs){
        setTimeout(rs, x, x)
    })
}

async function getPath(x) {
    var val = await readDir(x)
    return val / 100;
}

async function init() {
  var array = [4,56,2,3,34,45,65,23,23,12,12,23,34,43,54,54];  // lack of data in array
  var resultArr = array.map(function(val) {
      return getPath(val);
  });
  
  var result = await Promise.all(resultArr);
  console.log(result)
}

init()

node v10随附fs.promises,非常简洁。

async function getPath(x) {
   const files = await fs.promises.readdir(x)
   console.log(files)
}

所有异步函数均返回承诺