美文网首页
ECMAScript 词法和 excution context

ECMAScript 词法和 excution context

作者: YeLqgd | 来源:发表于2020-03-06 16:55 被阅读0次

Source code

Source code,即 ECMAScript 代码,由任意 Unicode code point(即码点,也称码位,上一篇笔记有)组成。词法分析时,ECMAScript 代码被转换成一系列的 input elements,这些 elements 可以分为 white space、line terminator、comment、token 几类。其中 Unicode 里的一些特定的码位被当做 white space 和 line terminator。comment 结尾的 line terminator 不被视作 comment 的内容,而是一个单独的 input element。

Token

token 可以分为如下几类:

  • identifier name
    • reversed word
      • keyword
      • future reversed word
      • null literal
      • boolean literal
    • identifier
  • punctuator
  • numeric literal
  • string literal
  • template(即字符串模板)

Lexical Environment

Lexical Environment 是一种 specification type,它用于根据 ECMAScript 词法嵌套代码定义标识符和特定的变量和函数之间的关联。包含 Environment Record 和一个对外部 lexical environment 的 reference 两个部分,当一个 environment record 是 global environment record 时,引用的值为 null。体现在对 ECMAScript 规范的实现上,这个 Lexical Environment 就是一种数据结构。通常,词法环境与 ECMAScript 代码的某些特定语法结构(例如,function declaration,block statement 或 try statement 的 catch 子句)相关联,并且每次此类代码被执行时都会创建一个新的 lexical environment。

Environment Record

规范里,Environment Record 是一个 Record(Record 是 ECMAScript 的 specification type 之一,可以理解成由 key-value pairs 组成的集合),在一个简单的面向对象的层次结构中,可以被认为是一个具有三个实体子类的抽象类:

  • Declaration Environment Record:通过 var、let、const、function、class、import 关键字声明定义的 identifier 及其对应的信息就记录在 Declaration Environment Record 里
  • Object Environment Record:与 with 语句相关
  • Global Environment Record:全局最外层的 environment record,ECMAScript 内置的对象和方法相关的信息就记录在此
    其中 Declaration Environment Record 又有两个子类:
  • Function Environment Record:一个函数内部最外层的 environment record
  • Module Environment Record:与 Module 有关
    正是这些类内部的方法决定了执行 ECMAScript 代码时,通过一个 identifier 如何访问到其对应值的机制。

Execution Context

是一个 specification device,用于追踪 ECMAScript 代码的执行。执行 ECMAScript 代码的过程中有可能有多个 execution contexts,这些execution contexts 通过栈来追踪,每生成一个新的 execution context 便将其推入栈,同一时间只有栈顶的那个 execution contexts 出于运行中,运行结束之后便将之出栈。生成新的 execution context 的情况有三种:

  • 执行全局的 ECMAScript 代码时
  • 执行 Module 代码
  • 执行一个 function 里的代码

每个 execution context 包含五个 component:

  • code evaluation state
  • Function:当执行的是 function 里的代码时,值为对应的 function object,否则为 null
  • Realm:不好理解,一个 iframe 和其 parent 的 execution context 里的 Realm 是不相同的,比如在某个 iframe 里执行 [1, 2, 3] instanceof window.parent.Array,结果是 false
  • VariableEnvironment:所有通过 var 声明的 identifiers 组成的 environment record 所对应的 lexical environment
  • LexicalEnvironment::所有通过 let、const、class 等声明的 identifiers 组成的 environment record 所对应的 lexical environment

NOTE

  • 在 let、const、class 声明 identifier 的语句前访问这些 identifier 会报错,即使 outer lexical environment 里已经有一个一样的 identifier,这也是造成所谓「临时性死区」的原因
  • 只有 function 和 Module 里的 var 声明的 identifier 不会被提升到 global environment record 里
  • 一个新的 execution context 生成时,必至少有一个新的 lexical environment 随之而生成,反之则不然
  • 普通函数里的 this 值由该函数调用的方式决定
  • 箭头函数里的 this 值由该函数被声明时所处的的 lexical environment 决定

参考:

相关文章

网友评论

      本文标题:ECMAScript 词法和 excution context

      本文链接:https://www.haomeiwen.com/subject/qosckhtx.html