简介
ES6中在引入异步编程的同时,也引入了Generators,通过yield关键词来生成对应的数据。同样的dart也有yield关键词和生成器的概念。
什么时候生成器呢?所谓生成器就是一个可能继续产生某些数据的安装,也叫做generator。
两种返回类型的generator
依据是同步生成还是异步生成,dart返回的后果也是不同的。
如果是同步返回,那么返回的是一个Iterable对象.
如果是异步返回,那么返回的是一个Stream对象。
同步的generator应用sync*关键词如下:
Iterable<int> naturalsTo(int n) sync* {
int k = 0;
while (k < n) yield k++;
}
异步的generator应用的是async* 关键词如下:
Stream<int> asynchronousNaturalsTo(int n) async* {
int k = 0;
while (k < n) yield k++;
}
生成关键词应用的是yield。
如果yield前面跟着的自身就是一个generator,那么须要应用yield*。
Iterable<int> naturalsDownFrom(int n) sync* {
if (n > 0) {
yield n;
yield* naturalsDownFrom(n - 1);
}
}
Stream的操作
stream示意的是流,失去这个流之后,咱们须要从流中取出对应的数据。
从Stream中取出数据有两种形式,第一种就是应用Stream自身的API来获取Stream中的数据。
最简略的就是调用stream的listen办法:
StreamSubscription<T> listen(void onData(T event)?,
{Function? onError, void onDone()?, bool? cancelOnError});
listen能够接数据的解决办法,具体应用如下:
final startingDir = Directory(searchPath);
startingDir.list().listen((entity) {
if (entity is File) {
searchFile(entity, searchTerms);
}
});
默认的办法是onData办法。
另外一种就是明天要解说的await for.
await for的语法如下:
await for (varOrType identifier in expression) {
// Executes each time the stream emits a value.
}
要留神的是下面的expression必须是一个Stream对象。并且await for必须用在async中,如下:
Future<void> main() async {
// ...
await for (final request in requestServer) {
handleRequest(request);
}
// ...
}
如果要想中断对stream的监听,则能够应用break或者return。
总结
以上就是dart中生成器的应用了。
本文已收录于 http://www.flydean.com/13-dart-generators/
最艰深的解读,最粗浅的干货,最简洁的教程,泛滥你不晓得的小技巧等你来发现!
欢送关注我的公众号:「程序那些事」,懂技术,更懂你!
发表回复