• ES6 Generator 函数


    Generator 函数是 ES6 提供的一种异步编程解决方案,语法行为与传统函数完全不同。

    形式上,Generator 函数是一个普通函数,但是有两个特征。一是,function关键字与函数名之间有一个星号;二是,函数体内部使用yield表达式,定义不同的内部状态(yield在英语里的意思就是“产出”)。

    1. function* generatorFunction() {
    2. yield 'Hello';
    3. yield 'World';
    4. yield '!';
    5. }
    6. // 创建一个迭代器对象
    7. const iterator = generatorFunction();

     Generator 函数的调用方法与普通函数一样,也是在函数名后面加上一对圆括号。不同的是,调用 Generator 函数后,该函数并不执行,必须调用遍历器对象的next方法,使得指针移向下一个状态。也就是说,每次调用next方法,内部指针就从函数头部或上一次停下来的地方开始执行,直到遇到下一个yield表达式(或return语句)为止。换言之,Generator 函数是分段执行的,yield表达式是暂停执行的标记,而next方法可以恢复执行。

    1. // 调用迭代器的next()方法获取值
    2. console.log(iterator.next()); // { value: 'Hello', done: false }
    3. console.log(iterator.next()); // { value: 'World', done: false }
    4. console.log(iterator.next()); // { value: '!', done: false }
    5. console.log(iterator.next()); // { value: undefined, done: true }

    总结:
    调用 Generator 函数,返回一个遍历器对象,代表 Generator 函数的内部指针。以后,每次调用遍历器对象的next方法,就会返回一个有着value和done两个属性的对象。value属性表示当前的内部状态的值,是yield表达式后面那个表达式的值;done属性是一个布尔值,表示是否遍历结束。

    ES6 没有规定,function关键字与函数名之间的星号,写在哪个位置。这导致下面的写法都能通过。

    1. function * foo(x, y) { ··· }
    2. function *foo(x, y) { ··· }
    3. function* foo(x, y) { ··· }
    4. function*foo(x, y) { ··· }

    由于 Generator 函数仍然是普通函数,所以一般的写法是第三种,即星号紧跟在function关键字后面。

  • 相关阅读:
    c语言数据结构 排序(三)
    【云栖2023】姜伟华:Hologres Serverless之路——揭秘弹性计算组
    【linux进程(五)】进程间切换以及环境变量问题
    垃圾回收 - 复制算法
    【C++】继承 ⑪ ( 多继承 | 多继承语法 | 多继承案例 )
    怎么将mp4改成mp3格式?
    使用 Elastic 输入包自定义你的数据摄取
    数说故事线下美妆店铺调研:店铺运营方法论分析
    深入理解Java单例模式和优化多线程任务处理
    TCP_IP协议
  • 原文地址:https://blog.csdn.net/tong200617/article/details/133940418