如何在 Dart 中 List.forEach() 中 Async/await

How to Async/await in List.forEach() in Dart

我正在编写某种机器人(命令行应用程序),但在使用“forEach”方法时遇到异步执行问题。 这是我正在尝试做的事情的简化代码:

main() async {
  print("main start");
  await asyncOne();
  print("main end");
}

asyncOne() async {
  print("asyncOne start");
  [1, 2, 3].forEach(await (num) async {
    await asyncTwo(num);
  });
  print("asyncOne end");
}

asyncTwo(num) async
{
  print("asyncTwo #${num}");
}

这是输出:

main start
asyncOne start
asyncOne end
main end
asyncTwo #1
asyncTwo #2
asyncTwo #3

我想得到的是:

main start
asyncOne start
asyncTwo #1
asyncTwo #2
asyncTwo #3
asyncOne end
main end

如果有人知道我做错了什么,我将不胜感激。

我认为使用 forEach 方法无法实现您想要的效果。但是,它将与 for 循环一起使用。例子;

asyncOne() async {
  print("asyncOne start");
  for (num number in [1, 2, 3])
    await asyncTwo(number);
  print("asyncOne end");
}

您不能为此使用 forEach,因为它实际上并不查看其回调的 return 值。如果他们是期货,他们只是迷路而不是等待。

你可以像 Steven Upton 建议的那样做一个循环,或者你可以使用 Future.wait 如果你希望操作同时 运行,而不是一个接一个地进行:

asyncOne() async {
  print("asyncOne start");
  await Future.wait([1, 2, 3].map(asyncTwo));
  print("asyncOne end");
}

您需要使用Future.forEach。

main() async {
  print("main start");
  await asyncOne();
  print("main end");
}

asyncOne() async {
  print("asyncOne start");
  await Future.forEach([1, 2, 3], (num) async {
    await asyncTwo(num);
  });
  print("asyncOne end");
}

asyncTwo(num) async
{
  print("asyncTwo #${num}");
}

我知道这是一个老问题,但我会在这里留下一个新答案,希望这对以后的人有所帮助。

您可以使用 forEach 来实现您想要实现的目标,方法如下:

  asyncOne() async {
  print("asyncOne start");
  await Future.forEach([1, 2, 3],(num) async {
    await asyncTwo(num);
  });
  print("asyncOne end");
}

使用 forEach 循环,即使您已经创建了自定义列表 class。

    lol() async {
  await Future.forEach(myListofFood,(Food food) async {
    await secondaryfuncton(food);
  });
}

如果需要迭代一个Map,可以使用:

await Future.forEach(myMap.keys, (key) async {
  final value = data[key];
}