JavaScript中的“功能*”是什么?

2020/10/10 11:40 · javascript ·  · 0评论

页面中,我找到了新的JavaScript函数类型:

// NOTE: "function*" is not supported yet in Firefox.
// Remove the asterisk in order for this code to work in Firefox 13 

function* fibonacci() { // !!! this is the interesting line !!!
    let [prev, curr] = [0, 1];
    for (;;) {
        [prev, curr] = [curr, prev + curr];
        yield curr;
    }
}

我已经知道了什么yieldlet以及[?,?]=[?,?]做的,但不知道什么function*是注定的。它是什么?

PS不会尝试使用Google,因为搜索带有星号的表达式不可能的它们被用作占位符)。

这是一个生成器功能。

生成器是可以退出并随后重新输入的函数。它们的上下文(变量绑定)将在重新进入时保存。

调用生成器函数不会立即执行其主体。而是返回该函数的迭代器对象。next()调用迭代器的方法时,将执行生成器函数的主体,直到第一个yield表达式指定要从迭代器返回的值,或者使用yield*,将其委托给另一个生成器函数。


历史记录:

这是的建议语法EcmaScript.next

Mozilla的Dave Herman谈到了EcmaScript.next30: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

这是一个生成器函数-它在您引用的页面中这样说,在注释中替换为“这是有趣的一行” ...

基本上,这是一种以编程方式指定序列的方法,以便可以传递它们并通过索引访问元素,而无需事先计算整个序列(大小可能无限)。

function*类型看起来像是可迭代过程的生成器函数。C#具有这样的功能,使用“收益率回报”参见12

本质上,此方法将每个值一个一个地返回到迭代此函数的对象,这就是为什么它们的用例在foreach样式循环中显示它的原因。

本文地址:http://javascript.askforanswer.com/javascriptzhongdegongnengshishenme.html
文章标签: ,   ,  
版权声明:本文为原创文章,版权归 javascript 所有,欢迎分享本文,转载请保留出处!

文件下载

老薛主机终身7折优惠码boke112

上一篇:
下一篇:

评论已关闭!