generator函数简单的理解

本文主要介绍了Generator函数,它是一个状态机,封装多个内部状态,形式上是普通函数但可暂停执行,函数名前加星号。调用它不执行,返回指向内部状态的指针对象。next方法分阶段执行,还能进行数据交换,参数可传入函数作为异步任务返回结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.generator函数的定义

语法上,可以把理解成,Generator 函数是一个状态机,封装了多个内部状态
形式上,Generator 函数是一个普通函数。它不同于普通函数,是可以暂停执行的,所以函数名之前要加星号,以示区别。
整个Generator函数就是一个封装的异步任务,或者说是异步任务的容器,异步操作需要暂停的地方,都用yield语句

yield的表达式形式
1.Generator函数特征:
(1)function 关键字和函数之间有一个星号(*),且内部使用yield表达式,定义不同的内部状态
(2)调用Generator函数后,该函数并不执行,返回的也不是函数运行结果,而是一个指向内部状态的指针对象

2.什么是Generator函数

function* gen(x){//一个 Generator 函数
	console.log('x='+x)
	var y = yield x + 2;
    
	return y;
}
//调用Generator 函数
var g = gen(1);

g.next();
输出:x=1
{value: 3, done: false}

注意:调用g.next() 即执行异步任务的  x+2  

换言之,next 方法的作用是分阶段执行 Generator 函数。每次调用 next 方法,会返回一个对象,表示当前阶段的信息( value 属性和 done 属性)。value 属性是 yield 语句后面表达式的值,表示当前阶段的值;done 属性是一个布尔值,表示 Generator 函数是否执行完毕,即是否还有下一个阶段(done为false 继续执行)

3.Generator 函数的数据交换

function* gen(x){
  var y = yield x + 2;
  return y;
}

var g = gen(1);
//第一次执行
g.next() // { value: 3, done: false }
//第二次执行 时,如果有带参数,
这个参数可以传入 Generator 函数,作为上个阶段异步任务的返回结果,被函数体内的变量 y 接收。
g.next(2) // { value: 2, done: true }
因此,这一步的 value 属性,返回的就是2(变量 y 的值)。

//如果没带参数
g.next() //{value: undefined, done: true}

第二个 next 方法带有参数2,这个参数可以传入 Generator 函数,作为上个阶段异步任务的返回结果,被函数体内的变量 y 接收。因此,这一步的 value 属性,返回的就是2(变量 y 的值)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值