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