0

我的要求如下:

我有 3 个大文件 big_file_1、big_file_2 和 big_file_3。我想异步读取这 3 个大文件,只有在所有文件的读取完成后才处理我的其余代码。

fs.readFile('big_file_1', function (err, data) {
  if (err) throw err;
  content_1 = data;
});
fs.readFile('big_file_2', function (err, data) {
  if (err) throw err;
  content_2 = data;
});
fs.readFile('big_file_3', function (err, data) {
  if (err) throw err;
  content_3 = data;
});
// Do something with content_1, content_2 and content_3

如何在 Node.JS 中实现这一点?

4

1 回答 1

2

您可以使用异步库parallel的功能来做到这一点:

async.parallel([
  fs.readFile.bind(fs, 'big_file_1'),
  fs.readFile.bind(fs, 'big_file_2'),
  fs.readFile.bind(fs, 'big_file_3')
], function (err, results) {
  if (err) throw err;
  content_1 = results[0]
  content_2 = results[1]
  content_3 = results[2]
  /* TODO do some cool stuff */
})

或者,您可以手动执行此操作:

int steps_done = 0
fs.readFile('big_file_1', function(err, data) {
  if (err) throw err
  content_1 = data
  if (++steps_done == 3) do_next_step()
})
fs.readFile('big_file_2', function(err, data) {
  if (err) throw err
  content_2 = data
  if (++steps_done == 3) do_next_step()
})
fs.readFile('big_file_3', function(err, data) {
  if (err) throw err
  content_3 = data
  if (++steps_done == 3) do_next_step()
})
于 2013-04-03T16:50:25.943 回答