JavaScript编译原理

1.分词/词法分析

首先来说一下什么是分词吧,分词就是将由字符组成的字符串分解成对于编程语言有意义的代码块。这些代码块就被成为词法单元。如var a = 2这段代码,会被分解为下面的词法单元。具体为:var,a,=,2。
注意:分词其实就是将上面的整段代码进行一个拆分为一段一段。

2.解析/语法分析

解析就是将词法单元流转换为一个有元素逐级嵌套所组成的代表了程序语法结构的树。这个树被称为:抽象语法树。鉴于这里过长的标准词,就不做考虑了,本人直接以一种更加直观的形式展示。具体如下图:
在这里插入图片描述
解析:抽象语法树会有一个var的顶级节点,之后会有一个变量为a的子节点以及赋值符=的一个节点。在赋值符下又有一个为2的子节点。具体就对应了var a = 2这段代码。

3.代码生成

将抽象语法树转换为可执行代码的过程被称为代码生成。这个过程与语言,目标平台息息相关。简单来说就是有某种方法可以将var a = 2的抽象语法树转换为机器的指令。用来创建一个叫做a的变量,并将一个值存储在a中。

4.LHS和RHS查询

执行JavaScript代码主要是依赖引擎。当引擎执行var a = 2时,会通过查找变量a来判断是否已经声明。查找的过程由作用域协助。在查询的过程中,引擎会为变量a进行LHS(左查询),会为值进行右查询。简单来说就是当变量出现在赋值操作的左侧时,进行LHS查询,出现在右侧时,进行RHS查询。更准确来说就是LHS查询试图找到变量的容器本身,RHS则是为了取到他的源值。
注意:在函数中,会出现既有LHS又有RHS查询。因为在传递参数的过程中,会代码会进行隐式的赋值。

5.异常

当变量还没声明的情况下,LHS查询和RHS查询的行为是不一样的。

function foo(a){
    console.log(a+b);
    b=a;
}
foo(2)

注意:第一次对b进行右查询是无法找到该变量的,也就是说这是一个未声明的变量,因为在任何相关的作用域中都无法找到他。如果RHS在所嵌套的作用域中遍寻不到所需的变量,引擎就会抛出异常。

6.小测验

function foo(a){
  var b=a;
  return a+b;
 }
 var c=foo(2)

问题:找出所有的LHS查询和RHS
答案:LHS(c=…,a=2,b=…)和RHS(foo(2…,=a,a…,…b))

7.小结

其实本章节更是一个偏向于理论的东西,了解这个对于了解JavaScript代码在执行时发生了什么很有帮助。因为最近相对空闲,所以会慢慢开始接着更文。希望各位小伙伴们在这里多多少少都能收获些前端小知识吧。祝各位越来越好。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值