async.parallel() 和 Promise.all() 都是用来处理异步任务的工具,但它们有些许不同。async.parallel() 用于并行的执行异步任务,而 Promise.all() 用于并行执行从多个 Promise 实例返回的异步任务,并等待它们全部完成后再执行下一步操作。它们之间最主要的区别在于:async.parallel() 支持并行执行不同类型的异步任务,而 Promise.all() 只能用于执行多个 Promise 实例。
以下是一个使用 async.parallel() 的代码示例:
const async = require('async');
// 异步执行任务的函数
function asyncTask(taskName, callback) {
setTimeout(() => {
console.log(`${taskName} 完成了`);
callback(null, taskName);
}, 1000);
}
// 并行执行异步任务
async.parallel([
function(callback) {
asyncTask('任务一', callback);
},
function(callback) {
asyncTask('任务二', callback);
},
function(callback) {
asyncTask('任务三', callback);
}
], function(err, results) {
console.log('全部任务完成了', results);
});
// 输出:
// 任务一 完成了
// 任务三 完成了
// 任务二 完成了
// 全部任务完成了 [ '任务一', '任务二', '任务三' ]
以下是一个使用 Promise.all() 的代码示例:
// 异步执行任务的函数,返回一个 Promise 实例
function asyncTask(taskName) {
return new Promise((resolve, reject) => {
setTimeout(() => {
console.log(`${taskName} 完成了`);
resolve(taskName);
}, 1000);
});
}
// 并行执行异步任务
Promise.all([
asyncTask('任务一'),
asyncTask('任务二'),
asyncTask('任务三')
]).then(results => {
console.log('全部任务完成了', results);
});
// 输出:
// 任务一 完成了
// 任务二 完成了
// 任务三 完成了
// 全部任务完成了 [ '任务一', '任务二', '任务三' ]
综上所述,虽然 async.parallel() 和 Promise.all() 用法不同,但它们都是常用的处理异步任务的工具。可以根据具体的