JavaScript函数的作用域链是哈希表吗?

发布于 2022-09-12 04:16:49 字数 175 浏览 21 评论 0

ps:作用域链是一个函数被创建的作用域中的对象的集合。
image.png
图取自《高性能JavaScript》
根据这张图以及考虑到JavaScript对象的数据结构是哈希表,所以我觉得作用域链也是一个哈希表,还请指教

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

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

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

感悟人生的甜 2022-09-19 04:16:49

作用域链

这是 ES6 Spec 里对作用域(ES6 叫词法环境)的解释。

8.1 Lexical Environments

A Lexical Environment is a specification type used to define the association of Identifiers to specific variables and functions based upon the lexical nesting structure of ECMAScript code. A Lexical Environment consists of an Environment Record and a possibly null reference to an outer Lexical Environment. Usually a Lexical Environment is associated with some specific syntactic structure of ECMAScript code such as a FunctionDeclaration, a BlockStatement, or a Catch clause of a TryStatement and a new Lexical Environment is created each time such code is evaluated.

A Lexical Environment consists of an Environment Record and a possibly null reference to an outer Lexical Environment.
词法环境由一个 环境记录表 和一个指向外部词法环境的引用(可能为null)构成。

这是一个链表结构。 lexicalEnv -> outer -> outer 最终指向 globalEnv 。

函数对象对作用域是怎么引用的?

Spec 9.2 章节也有介绍: 函数对象有一个内部槽(属性)[[Environment]], 指向函数创建时候的词法环境。当函数被运行的时候,这个环境就会被当作运行环境的外部环境。

image.png

综上,作用域链是链表形式,函数只引用了外一层的环境。

伴我心暖 2022-09-19 04:16:49

作用域链从访问的角度来看确实是一个集合,但不单是一个集合。
查找的时候向上查找,是有序的;由于嵌套的内外层会有覆盖,变量名也不单一,只是对访问者是单一的。
从访问的角度,确实可以把某个函数执行时可访问的所有变量放到一个哈希表里,但是这个哈希表不能完整描述这条作用域链的特征(链条长了之后读取时间变长,而哈希表理论上不应存在这样的差距)。
楼上说得对。

别挽留 2022-09-19 04:16:49

你是说函数执行的堆栈?

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