简单理解 JavaScript 编译原理和区别 (作用域与闭包 - Ch1.1)

文章探讨了编程中的变量存储和访问,特别是在传统编译语言和JavaScript引擎中的处理方式。传统编译语言经历词法分析、语法分析和代码生成三个步骤,而JavaScript引擎在执行前编译并优化代码,重点关注运行性能。作用域是管理和查找变量的关键规则。

变量

编程语言中最基础的功能就是 变量,存储和访问 变量 的能力将 状态 带给了程序。
问题是:变量存储在哪里?更重要的是程序如何找到他们?
说明需要设计一套良好的规则来存储变量,并方便找到他们,这就是 作用域

传统编译语言

程序中的一段源代码经过三个步骤,统称 编译

  • 词法分析:
    将每一段代码分解成有意义的代码块
    比如 var = 1 分解成 var=1
  • 语法分析
    这个过程将 词法单元流 转换成一个代表程序语法结构的树,称为 抽象语法树
    比如VariableDeclaration 节点下面包含一个 Identifier = varAssignmentExpression 节点,
    AssignmentExpression 又包含了 NumericLiteral = 1 节点。
  • 代码生成
    抽象语法树 转换成可执行代码,这个过程和 语言、目标平台 紧密相关。
    简单来说就是有某种办法可以让 var = 1抽象语法树 变成一系列机器指令来执行这个操作。

JavaScript 引擎

  • JavaScript 引擎在 语法分析代码生成 过程中有特定的步骤对运行性能进行优化。
  • JavaScript 引擎没有大量的时间进行优化,编译过程不是发生在构建之前的。
    通常JS代码片段在执行前进行编译,进行编译以后就会做好执行他的准备,并马上执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值