这是一个生成器函数。
生成器是可以退出然后重新进入的函数。它们的上下文(变量绑定)将在重新进入时保存。
调用生成器函数不会立即执行其主体;而是返回该函数的迭代器对象。当迭代器的next()
方法被调用时,生成器函数的主体将被执行,直到第一个yield
表达式,它指定要从迭代器返回的值,或者yield*
委托给另一个生成器函数。
历史记录:
这是EcmaScript.next
.
Mozilla 的 Dave Herman 发表了关于EcmaScript.next 的演讲。在30:15,他谈到了发电机。
早些时候,他解释了 Mozilla 如何实验性地实施拟议的语言更改以帮助指导委员会。Dave 与 Mozilla 的 CTO(我认为)和原始 JavaScript 设计师 Brendan Eich 密切合作。
您可以在 EcmaScript 工作组 wiki 上找到更多详细信息:http ://wiki.ecmascript.org/doku.php?id=harmony:generators
工作组 (TC-39) 普遍同意 EcmaScript.next 应该有某种生成器迭代器提案,但这不是最终的。
在下一版本的语言中,您不应该依赖它的显示,即使它没有改变,它也可能不会在一段时间内广泛地出现在其他浏览器中。
概述
一级协程,表示为封装挂起执行上下文(即函数激活)的对象。现有技术:Python、Icon、Lua、Scheme、Smalltalk。
例子
斐波那契数列的“无限”序列(尽管行为在 2 53附近):
function* fibonacci() {
let [prev, curr] = [0, 1];
for (;;) {
[prev, curr] = [curr, prev + curr];
yield curr;
}
}
生成器可以在循环中迭代:
for (n of fibonacci()) {
// truncate the sequence at 1000
if (n > 1000)
break;
print(n);
}
生成器是迭代器:
let seq = fibonacci();
print(seq.next()); // 1
print(seq.next()); // 2
print(seq.next()); // 3
print(seq.next()); // 5
print(seq.next()); // 8