如何在 Dart 中的 List.forEach() 中异步/等待

问题描述 投票:0回答:7

我正在编写某种机器人(命令行应用程序),当我使用“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

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

flutter dart asynchronous foreach
7个回答
287
投票

你需要使用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}");
}

79
投票

我认为用

forEach
方法不可能达到你想要的效果。然而,它可以与
for
循环一起使用。示例;

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

18
投票

您不能为此使用

forEach
,因为它实际上并不查看其回调的返回值。如果它们是未来,它们只会丢失而不被等待。

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

Future.wait

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

12
投票

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

您可以使用 forEach 来实现您想要通过执行以下操作来实现的目标:

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

2
投票

即使您已经创建了自定义类列表,也请使用

forEach
循环。

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

2
投票

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

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

1
投票

这个解决方案的优点是它可以与

mapIndexed

一起使用
await Future.wait([1, 2, 3].map(  // or mapIndexed(
  (num) async {
    await asyncTwo(num);
  }));
© www.soinside.com 2019 - 2024. All rights reserved.