湛江网站建设策划8插槽x8插槽
2026/4/18 10:26:17 网站建设 项目流程
湛江网站建设策划,8插槽x8插槽,wordpress的二次开发,网站流媒体播放如何做拒绝玄学#xff0c;看透本质#xff1a;图解 JavaScript 词法环境与内存引用 很多同学在学习闭包时#xff0c;往往只记住了“子函数可以使用父函数的变量”这个结论#xff0c;却对底层的**“词法环境#xff08;Lexical Environment#xff09;”**知之甚少。 本文将剥…拒绝玄学看透本质图解 JavaScript 词法环境与内存引用很多同学在学习闭包时往往只记住了“子函数可以使用父函数的变量”这个结论却对底层的**“词法环境Lexical Environment”**知之甚少。本文将剥离所有晦涩的术语堆砌通过一段经典代码深入内存底层向你展示**代码逻辑Code、变量数据Data和执行环境Environment**在运行时的真实物理关系。案例代码我们以这段经典的闭包代码为例JavaScript// 全局环境 let a 100 function fun() { let timer 0 // 局部变量 // 定义内部函数 function test() { timer console.log(timer) } return test } // 核心时刻函数执行并返回内部函数 const myTest fun()第一部分直觉的误区为什么你会困惑初学者最容易犯的错误是认为内存结构等同于代码结构。错误的静态视角“因为代码里 test 嵌套在 fun 里所以内存里 test 的数据也死死地包在 fun 里。fun 执行完这块空间就该销毁或者一直死板地存在那里。”这种“俄罗斯套娃”式的直觉如下图无法解释为什么fun执行完了timer还能被访问也无法解释什么是“动态的作用域链”。Code snippet全局内存let a 100fun 的内部空间 (静态嵌套)let timer 0function test 代码第二部分揭秘真相——什么是“词法环境”要理解闭包必须先理解 JavaScript 引擎执行代码时的分离存储原则。在 JavaScript 运行时“代码逻辑”和“状态数据”是分开存放的靠“引用指针”连接。而管理这些状态数据的核心结构就叫词法环境Lexical Environment。1. 核心概念定义一个标准的词法环境由两部分组成环境记录器Environment Record这就是一个“登记表”专门用来存放变量和函数的声明。比如timer 0就记在这里。外部环境引用Outer Reference这是一个“指针”指向父级的词法环境。这就是作用域链的物理实体。2. 运行时拆解变量、函数、代码究竟在哪当执行const myTest fun()这行代码时内存中发生了极其精密的动态构建过程。请配合下方的高维内存模型图来阅读变量存在哪数据当 fun() 被调用时引擎在内存中创建了一个全新的词法环境Lexical Environment。变量 timer 的值 0 被保存在这个环境的环境记录器中。代码存在哪逻辑函数 test 的代码逻辑即函数体内的字符串并不存储在词法环境里而是存储在堆内存Heap 中一个独立的函数对象Function Object里。它们如何相互引用关键这是最关键的一步。当 test 函数对象被创建时引擎会给它装上一个不可见的内部属性 [[Environment]]。这个属性直接指向了 fun 执行时创建的那个词法环境。第三部分一张图看懂内存物理结构下面的 Mermaid 图解展示了fun()执行瞬间的真实内存快照。请重点关注代码存储Heap与环境记录Stack/Context的分离与连接。Code snippet堆内存 (存储函数实体/代码)执行环境栈 (存储变量状态)全局词法环境 (Global LE)fun 函数词法环境 (Fun LE)myTest 引用闭包核心[[Environment]] 指针强引用ƒ fun() 对象实体Code: ...ƒ test() 对象实体Code: timer ...-----------------------[[Environment]]内部插槽环境记录器:timer: 0Outer: - Global LE环境记录:a: 100fun: pointer - func_funmyTest: pointer - func_testOuter: null第四部分总结与顿悟通过上图我们可以回答最初的困惑为什么 fun 执行完timer 不消失看图中的红色粗线。虽然 fun 函数执行结束了但返回的 test 函数对象里有一个 [[Environment]] 指针死死地拉住了 fun 的词法环境。只要 myTest 还在引用 test 对象这个Fun LE方块就永远无法被垃圾回收。代码和环境是如何分离的test 的代码逻辑静静地躺在堆内存里右边而它所需要操作的数据 timer 躺在动态生成的词法环境里左边。两者通过指针跨越内存区域相连。所谓闭包本质上就是一个函数对象代码保留了对它出生地词法环境的引用。理解了这一点你就理解了 JavaScript 内存模型的核心。

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询