zoukankan      html  css  js  c++  java
  • ES6知识点整理之----Generator----API

    Generator.prototype.throw()

    可以在函数体外抛出错误,然后在 Generator 函数体内捕获。

    var g = function* () {
      try {
        yield;
      } catch (e) {
        console.log('内部捕获', e);
      }
    };
    
    var i = g();
    i.next();
    
    try {
      i.throw('a');
      i.throw('b');
    } catch (e) {
      console.log('外部捕获', e);
    }
    // 内部捕获 a
    // 外部捕获 b

    如果 Generator 函数内部没有部署try...catch代码块,那么throw方法抛出的错误,将被外部try...catch代码块捕获。

    如果 Generator 函数内部和外部,都没有部署try...catch代码块,那么程序将报错,直接中断执行。

    throw方法抛出的错误要被内部捕获,前提是必须至少执行过一次next方法。

    throw方法被捕获以后,会附带执行下一条yield表达式。也就是说,会附带执行一次next方法。

    throw命令与g.throw方法是无关的,两者互不影响。

    函数体内捕获错误的机制,大大方便了对错误的处理。多个yield表达式,可以只用一个try...catch代码块来捕获错误。如果使用回调函数的写法,想要捕获多个错误,就不得不为每个函数内部写一个错误处理语句,现在只在 Generator 函数内部写一次catch语句就可以了。

    Generator 函数体外抛出的错误,可以在函数体内捕获;反过来,Generator 函数体内抛出的错误,也可以被函数体外的catch捕获。

    一旦 Generator 执行过程中抛出错误,且没有被内部捕获,就不会再执行下去了。如果此后还调用next方法,将返回一个value属性等于undefineddone属性等于true的对象,即 JavaScript 引擎认为这个 Generator 已经运行结束了。

    Generator.prototype.return()

    可以返回给定的值,并且终结遍历 Generator 函数。

    function* gen() {
      yield 1;
      yield 2;
      yield 3;
    }
    
    var g = gen();
    
    g.next()        // { value: 1, done: false }
    g.return('foo') // { value: "foo", done: true }
    g.next()        // { value: undefined, done: true }

    如果return方法调用时,不提供参数,则返回值的value属性为undefined

    如果 Generator 函数内部有try...finally代码块,那么return方法会推迟到finally代码块执行完再执行。

    next()、throw()、return() 的共同点

    它们的作用都是让 Generator 函数恢复执行,并且使用不同的语句替换yield表达式。

    next()是将yield表达式替换成一个值

    throw()是将yield表达式替换成一个throw语句。

    return()是将yield表达式替换成一个return语句。

    const g = function* (x, y) {
      let result = yield x + y;
      return result;
    };
    
    const gen = g(1, 2);
    gen.next(); // Object {value: 3, done: false}
    
    gen.next(1); // Object {value: 1, done: true}
    // 相当于将 let result = yield x + y
    // 替换成 let result = 1;
    
    gen.throw(new Error('出错了')); // Uncaught Error: 出错了
    // 相当于将 let result = yield x + y
    // 替换成 let result = throw(new Error('出错了'));
    
    gen.return(2); // Object {value: 2, done: true}
    // 相当于将 let result = yield x + y
    // 替换成 let result = return 2;
  • 相关阅读:
    回顾
    单例模式
    元类
    反射和内置方法
    issubclass 和 isinstance和断点调试
    绑定方法和非绑定方法
    并发编程:IO多路复用。
    基于tcp的下载文件,以及struct模块的应用。
    并发编程:协程,异步调用。
    并发编程:GIL,线程池,进程池,阻塞,非阻塞,同步,异步
  • 原文地址:https://www.cnblogs.com/adhehe/p/9681342.html
Copyright © 2011-2022 走看看