- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
对于ES6生成器,为什么this blog post的作者说:
来自:http://davidwalsh.name/es6-generators
"The first next(..) call, we don't send in anything. Why? Because there's no yield expression to receive what we pass in."
第一个 it.next()
不是调用 (yield (x + 1))
吗?
function *foo(x) {
var y = 2 * (yield (x + 1));
var z = yield (y / 3);
return (x + y + z);
}
var it = foo( 5 );
// note: not sending anything into `next()` here
console.log( it.next() ); // { value:6, done:false }
console.log( it.next( 12 ) ); // { value:8, done:false }
console.log( it.next( 13 ) ); // { value:42, done:true }
You can see that we can still pass in parameters (x in our example) with the initial foo( 5 ) iterator-instantiation call, just like with normal functions.
The first next(..) call, we don't send in anything. Why? Because there's no yield expression to receive what we pass in.
最佳答案
第一个 it.next()
对应于 yield(x + 1)
,结果如预期的那样为 6。下一次调用 it.next(12)
时的 12 将第一个 yield 的值设置为 12,因此 y
设置为它的两倍,即 24 和迭代器结果值 (y/3)
,即 8。对 it.next(13)
的最终调用将第二个 yield 的值设置为 13,即设置为 z
,并接收 return
的值,即 5 + 24 + 13。
当然,由于语法原因,它有点令人困惑
z = yield(y / 3)
这看起来像是将与 y/3
相关的值分配给 z
。事实并非如此。 y/3
是作为迭代器值产生的值,而 z
被分配给由以下 it.next()
调用,完全不同的东西!省略括号并将其写为
var y = 2 * yield x + 1;
var z = yield y / 3;
请记住,yield
是一个语句,而不是函数调用。
至于您提到的错误,例如在 traceur 中它是“将值发送给新生生成器”。当您考虑它时,这是有道理的。作为参数发送到 it.next()
的值成为生成器中最近 yield 的值。在第一次调用 it.next()
时,生成器中 没有最新的 yield ,因此没有任何东西可以接受传递的值,因此出现错误。
不要混淆将参数传递给生成器(在您的情况下为 x
),它仅提供一种配置或初始化生成器的方法,将参数传递给 it.next()
,作为生成器中最近的 yield
的值。
考虑如何编写等效的手动生成器可能会有所帮助(简化为仅返回下一个值而不是 {value, done}
,并在生成器结束时抛出气体):
function foo(x) {
var y, z, step = 0;
return function next(val) {
switch (step++) {
case 0: return x + 1; break;
case 1: y = 2 * val; return y / 3; break;
case 2: z = val; return x + y + z; break;
default: throw "generator finished";
}
};
}
然后:
iterator = foo(5);
iterator(); // 6
iterator(12); // 8
iterator(13); // 42
关于javascript - ES6 生成器 - 第一个 next() 没有 yield 表达式的示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26695346/
我使用以下代码和嵌套生成器迭代文本文档并使用 get_train_minibatch() 返回训练示例。我想保留( pickle )生成器,这样我就可以回到文本文档中的相同位置。但是,您不能 pick
在本教程中,您将借助示例了解 JavaScript 生成器。在 JavaScript 中,生成器提供了一种使用函数和迭代器的新方法。 使用生成器, 您可以从函数内部的任何位置停止执行函数 并从
LESS is very cool .我一直想知道是否有任何好的 html 生成器可以让我更轻松地编写表单或做其他事情。除了 html,是否有一些类似的东西? 最佳答案 已尝试 Haml ? 从它的网
前言 如果是做python或者其他语言的小伙伴,对于生成器应该不陌生。但很多php开发者或许都不知道生成器这个功能,可能是因为生成器是php 5.5.0才引入的功能,也可以是生成器作用不是很明显。
我正在尝试编写一个使用生成器语法生成日期时间列表的函数: let dateRange = let endDate = System.DateTime.Parse("6/1/2010")
我遇到了一些看起来像的代码: [func(val) for val in iterable] 有一个可迭代对象(在我的例子中是一个生成器),用户想要为其副作用调用每个值的函数(例如 func 可以只是
Delphi 有内置的东西来生成 UUID 吗? 最佳答案 program Guid; {$APPTYPE CONSOLE} uses SysUtils; var Uid: TGuid; Result
我正在深入研究 javascript 生成器,但我真的很困惑。 我使用 node@0.11.x 运行此示例: function find() { process.nextTick(functi
有人知道一些关于如何为 hibernate 创建自定义 ID 生成器的好教程吗? 最佳答案 在 Google 上粗略搜索“hibernate 自定义 id 生成器教程”发现了以下可能性。我排除了那些看
我正在关注 Python 大师 David Beazley 的幻灯片。它指出“生成器也用于并发。这是一个示例: from collections import deque def countdown(
我有一个生成事件的生成器,我想用可以从 API 获取的附加元数据来丰富它。 某些事件具有与其链接的对象 ID,而其他事件则具有对象的哈希值,但不能同时具有两者。我无法根据哈希获取对象 id,我只能执行
假设我有一个自定义类: public class CustomClass { private String name; private String data; public
我正在考虑实现一个函数来在 SQL 请求中“构建”WHERE 子句,如下所示: "SELECT * FROM table $where" 使用如下所示的循环构建 $where: $arr=array(
我正在寻找执行此操作的标准函数: def Forever(v): while True: yield v 这看起来太琐碎了,我不敢相信没有标准版本。 就此而言,有人知道指向所有标准生成器函
我知道这个网站上有几个非常相似的相关问题,但是在看了这部剧之后,我相信这个问题本身就是独一无二的。如果有人能找到并提供证据证明我的问题完全被骗了,我会自己撤回它(所以请不要否决这个!)。 我是 Jav
void __fastcall TForm1::Button1Click(TObject *Sender) { int size = MemoEnter->GetTextLen() + 1;
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我试图在我的生成器的以下两个定义之间做出决定。哪个更好?哪个“更像 python ”?无论如何,有没有办法减轻每一个的缺点? def myGenerator1(howMany): result
我有一个 Python 生成器 lexg,它在每次迭代时生成一个列表。该代码似乎在传统的 for 循环意义上工作,即 for i in lexg(2,2): print(i) 产生: [2, 0] [
我希望这不会超出 Python 生成器的能力,但我想构建一个这样,每次调用该函数时,它都会返回下一分钟直到结束时间。 因此该函数读取开始时间和结束时间,并以分钟为单位返回时间,直到涵盖其间的所有时间。
我是一名优秀的程序员,十分优秀!