es6 的 generator 是什么?

发布于 2022-01-28 22:41:47 字数 997 浏览 1080 评论 0

generator 指的是

function* xxx(){
}

是 es6 里的写法。

function* test() {
    console.log('1');
    yield 1;
    console.log('2');
    yield 2;
    console.log('3');
}

代码中间插了两行 yield,代表什么呢?

  • 当 test 执行到 yield 1这一行的时候,程序将被挂起,要等待执行下一步的指令;
  • 当接收到指令后,test 将继续往下运行,直到 yield 2这一行,然后程序又被挂起并等待指令;
  • 收到指令后,test 又将继续运行,而下面已经没有 yield 了,那么函数运行结束。

这是不是就像,我们调试代码的时候,给插的断点 ?

当然,断点这个比喻,只是表象上比较相像,实质原理还是有非常大差异。

yield 就是让后面的 generator 执行完成后,才继续往下走。

要注意,function 后面多了一个星号,这样是表明这个函数将变成一个生成器函数,而不是一个普通函数了。意思就是,test 这个函数,将不能被这样执行

test(); 但可以获得一个生成器

var gen = test(); // gen 就是一个生成器了 然后,生成器可以通过 next() 来执行运行

gen.next();

也就是上面说的,让函数继续运行的指令。

简单地总结一下:

  • 生成器通过 yield 设置了一些类似”断点“的东西,使得函数执行到 yield 的时候会被阻断;
  • 生成器要通过 next() 指令一步一步地往下执行(两个 yield 之间为一步);
  • yield 语句后面带着的表达式或函数,将在阻断之前执行完毕;
  • yield 语句下面的代码,将不可能在阻断之前被执行;

由此可以看出,yield 是如何将异步非阻塞代码,变成 异步阻塞代码。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

文章
评论
84963 人气
更多

推荐作者

微信用户

文章 0 评论 0

小情绪

文章 0 评论 0

ゞ记忆︶ㄣ

文章 0 评论 0

笨死的猪

文章 0 评论 0

彭明超

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文