ecma6 yield

function * generator(k){
   console.log(‘begin‘);
   var x = yield k;
   console.log(‘x:‘,x);
   var y = yield x+k;
   console.log(‘y:‘,y);
   return x+y+k;
}

var o = generator(1);
var r = o.next();
console.log(‘1:‘+r.value, ‘done:‘+r.done);
r = o.next(3);
console.log(‘2:‘+r.value,‘done:‘+r.done);
r = o.next(5);
console.log(‘3:‘+r.value,‘done:‘+r.done);

//log
begin
1:1 done:false
x: 3
2:4 done:false
y: 5
3:9 done:true

===========================================================================
function * generator(k){
   console.log(‘begin‘);
   var x = yield k;
   console.log(‘x:‘,x);
   return ‘end‘;
   var y = yield x+k;
   console.log(‘y:‘,y);
   return x+y+k;
}

var o = generator(1);
var r = o.next();
console.log(‘1:‘+r.value,‘done:‘+r.done);
r = o.next(3);
console.log(‘2:‘+r.value,‘done:‘+r.done);
r = o.next(5);
console.log(‘3:‘+r.value,‘done:‘+r.done);

//log
begin
1:1 done:false
x: 3
2:end done:true
3:undefined done:true

迭代构造器可以接受初值,在构造时传入而非首次调用 next 时,
yield 后面的值被返回,后继代码暂时中断,直到调用 next 方法,

yield 赋值表达式:在下一次调用 next 时将传入的值赋給变量,

如果遇到 return 则迭代执行结束

时间: 2024-10-17 13:53:52

ecma6 yield的相关文章

javascript新特性let,function*,yield,promise

自从去了百度就好久没有更新博客了,看了以前写的东东,以前在小公司还是比较闲啊.讽刺的是这次又要换工作去小公司,才想起写篇博... 去了百度后先学了python,然后前面的GG走了,我也不想用python了,就全力转用nodejs了. 越来越喜欢上JS家族了,最近看了一下ECMA6的新特性,着实又增强了JS的生命力啊.看国外ASMJS大牛的视频说,JS的作者只用了10天就创造了这门语言. 所以希望ECMA能够继续进步. 废话多了些.下面干货来了.注意一下代码要用node --harmony执行,代

关于Python中的yield

关于Python中的yield http://www.cnblogs.com/tqsummer/archive/2010/12/27/1917927.html http://www.ibm.com/developerworks/cn/opensource/os-cn-python-yield/ 一.迭代器(iterator) 在Python中,for循环可以用于Python中的任何类型,包括列表.元祖等等,实际上,for循环可用于任何“可迭代对象”,这其实就是迭代器 迭代器是一个实现了迭代器协议

ruby yield 关键字用法实例

yield关键字我是这样理解,用它来占一个位置,先标记下这个地方将来要写代码的,等到调用的时候,再来编写具体的代码.有点像函数指针,或者C#里的委托,但其实并不太一样. 写测试接口的时候,每次的assert返回值不一样,但函数体大部分是相同的,只有参数不同.正好最近看到了yield,就熟悉一下用法,可以把assert这部分code写在yield 的位置. 例子主要就是test_nodes这个函数的定义 和 它的调用. Code: 1 def generate_nodes(n=3) 2 retur

lua协程一则报错解决“attempt to yield across metamethod/C-call boundary”

问题 attempt to yield across metamethod/C-call boundary 需求跟如下帖子中描述一致: http://bbs.chinaunix.net/forum.php?mod=viewthread&action=printable&tid=4065715 模拟一个场景,在C中创建出coroutine来执行Lua脚本,并且提供C API给Lua使用,当某些操作可能会阻塞时(如网络I/O),C函数中执行yield将协程切换出去,然后未来的某个时刻,如果条件

yield生成器及字符串的格式化

一.生成器 1 def ran(): 2 print('Hello world') 3 yield 'F1' 4 5 print('Hey there!') 6 yield 'F2' 7 8 print('goodbye') 9 yield 'F3' 10 11 ret = ran() # ran()称为生成器函数,ret才是生成器,仅仅具有一种生成能力,函数内部要有关键字yield 12 print(ret) 13 14 res = ret.__next__() #对生成器进行循环操作,遇到y

利用 Python yield 创建协程将异步编程同步化

在 Lua 和 Python 等脚本语言中,经常提到一个概念: 协程.也经常会有同学对协程的概念及其作用比较疑惑,本文今天就来探讨下协程的前世今生. 首先回答一个大家最关心的问题:协程的好处是什么? 通俗易懂的回答: 让原来要使用 异步 + 回调 方式写的非人类代码,可以用看似同步的方式写出来. 1.回顾同步与异步编程 同步编程即线性化编程,代码按照既定顺序执行,上一条语句执行完才会执行下一条,否则就一直等在那里. 但是许多实际操作都是CPU 密集型任务和 IO 密集型任务,比如网络请求,此时不

sleep、yield和join

(1)sleep和yield都是Thread类的静态方法,都会使当前处于运行状态的线程放弃CPU,但两者的区别在于: sleep给其它线程运行的机会,但不考虑其它线程的优先级:但yield只会让位给相同或更高优先级的线程: 当线程执行了sleep方法后,将转到阻塞状态,而执行了yield方法之后,则转到就绪状态: sleep方法有可能抛出异常,而yield则没有: 在一般情况下,我们更建议使用sleep方法. (2)join方法用于等待其它线程结束,当前运行的线程可以调用另一线程的join方法,

python yield

http://www.jb51.net/article/15717.htm  这里还不错 只是粗略的知道yield可以用来为一个函数返回值塞数据,比如下面的例子: def addlist(alist):    for i in alist:        yield i + 1 取出alist的每一项,然后把i + 1塞进去.然后通过调用取出每一项: alist = [1, 2, 3, 4]for x in addlist(alist):    print x, 这的确是yield应用的一个例子

php5.5新特性之yield理解

今天,在阅读别人代码时,其中出现了一个陌生的关键字yield,想一探究竟,于是找到:http://php.net/manual/zh/language.generators.overview.php yield生成器是php5.5之后出现的,yield提供了一种更容易的方法来实现简单的迭代对象,相比较定义类实现 Iterator 接口的方式,性能开销和复杂性大大降低. yield生成器允许你 在 foreach 代码块中写代码来迭代一组数据而不需要在内存中创建一个数组. 使用示例: /** *