JavaScript编译原理怎样理解,包括哪些内容
Admin 2022-08-22 群英技术资讯 623 次浏览
首先来说一下什么是分词吧,分词就是将由字符组成的字符串分解成对于编程语言有意义的代码块。这些代码块就被成为词法单元。如var a = 2
这段代码,会被分解为下面的词法单元。具体为:var,a,=,2。
注意:分词其实就是将上面的整段代码进行一个拆分为一段一段。
解析就是将词法单元流转换为一个有元素逐级嵌套所组成的代表了程序语法结构的树。这个树被称为:抽象语法树。鉴于这里过长的标准词,就不做考虑了,本人直接以一种更加直观的形式展示。具体如下图:
解析:抽象语法树会有一个var的顶级节点,之后会有一个变量为a的子节点以及赋值符=的一个节点。在赋值符下又有一个为2的子节点。具体就对应了var a = 2
这段代码。
将抽象语法树转换为可执行代码的过程被称为代码生成。这个过程与语言,目标平台息息相关。简单来说就是有某种方法可以将var a = 2
的抽象语法树转换为机器的指令。用来创建一个叫做a的变量,并将一个值存储在a中。
执行JavaScript代码主要是依赖引擎。当引擎执行var a = 2时,会通过查找变量a来判断是否已经声明。查找的过程由作用域协助。在查询的过程中,引擎会为变量a进行LHS(左查询),会为值进行右查询。简单来说就是当变量出现在赋值操作的左侧时,进行LHS查询,出现在右侧时,进行RHS查询。更准确来说就是LHS查询试图找到变量的容器本身,RHS则是为了取到他的源值。
注意:在函数中,会出现既有LHS又有RHS查询。因为在传递参数的过程中,会代码会进行隐式的赋值。
当变量还没声明的情况下,LHS查询和RHS查询的行为是不一样的。
function foo(a){ console.log(a+b); b=a;}foo(2)
注意:第一次对b进行右查询是无法找到该变量的,也就是说这是一个未声明的变量,因为在任何相关的作用域中都无法找到他。如果RHS在所嵌套的作用域中遍寻不到所需的变量,引擎就会抛出异常。
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))
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了until将watch最常用的逻辑进行封装简化代码写法,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
目录前言FabricObject 基类的实现抽离共同属性抽离共同方法Rect 类的实现本章小结前言在上个章节中我们已经创建了画布,接下来就可以进行物体的绘制了,那具体要怎么画呢?根据文章标题可以猜到应该是要抽象出一个物体基类,归纳出一些它们的共性,那它们能有啥共性呢,毕竟每个物体好像都是各画各的。对于这个问题大家可以先
nodejs新建空目录用fs模块的mkdir()方法,该方法会以异步的方式创建文件目录,如果目录已存在,将抛出异常;语法“fs.mkdir(path, [mode], [callback(err)])”。
JavaScript求两个数字中最大值的方法:1、利用Math对象的max()方法,语法“Math.max(数字1, 数字2);”;2、利用三元运算符,语法“数字1>数字2 ? 数字1 : 数字2;”。
这篇文章主要介绍了Vue3 列表界面数据展示,文章主要详介绍的内容就是做的就是把打到页面的数据,带样式,也就是说好看点显示,需要的朋友可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008