ECMAScript 词法和 excution context

2020-03-06  本文已影响0人  YeLqgd

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 可以分为如下几类:

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 组成的集合),在一个简单的面向对象的层次结构中,可以被认为是一个具有三个实体子类的抽象类:

Execution Context

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

每个 execution context 包含五个 component:

NOTE

参考:

上一篇 下一篇

猜你喜欢

热点阅读