使用await和async關鍵字
//必須在使用await關鍵字的所屬方法使用async標記
Future checkVersion() async {
var version = await lookUpVersion();
print(version);
}
//如果在主函數使用,也需要添加async標記
Future main() async {
checkVersion();
print('In main: version is ${await lookUpVersion()}');
}
String lookUpVersion() => "1.0.1";
//如果將其更改爲async函數(例如,因爲將來的實現會很耗時),則返回的值將爲Future:
Future<String> lookUpVersion() async => '1.0.0';
流處理
Future main() async {
// ...
await for (var request in requestServer) {
handleRequest(request);
}
// ...
}
發生器
//要實現同步生成器函數,請將函數主體標記爲sync*,並使用yield語句來傳遞值:
Iterable<int> naturalsTo(int n) sync* {
int k = 0;
while (k < n) yield k++;
}
//要實現異步生成器函數,請將函數主體標記爲async*,並使用yield語句傳遞值:
Stream<int> asynchronousNaturalsTo(int n) async* {
int k = 0;
while (k < n) yield k++;
}
//如果生成器是遞歸的,則可以使用yield*以下方法來提高其性能:
Iterable<int> naturalsDownFrom(int n) sync* {
if (n > 0) {
yield n;
yield* naturalsDownFrom(n - 1);
}
}