JavaScript编译原理怎样理解,包括哪些内容
Admin 2022-08-22 群英技术资讯 994 次浏览
关于“JavaScript编译原理怎样理解,包括哪些内容”的知识有一些人不是很理解,对此小编给大家总结了相关内容,具有一定的参考借鉴价值,而且易于学习与理解,希望能对大家有所帮助,有这个方面学习需要的朋友就继续往下看吧。
首先来说一下什么是分词吧,分词就是将由字符组成的字符串分解成对于编程语言有意义的代码块。这些代码块就被成为词法单元。如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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章给大家介绍的是Vue中ref与toRef的区别,ref与toRef还是有一定的不同的,大家在使用时要注意,下文有详细的介绍,希望大家阅读完这篇能有收获,接下来一起跟随小编看看吧。
这篇文章主要介绍了解决Vue watch里调用方法的坑,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
这篇文章主要为大家详细介绍了VUE实现时间轴播放组件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章主要给大家分享jQuery替换掉所有的类名的方法,小编觉得挺实用的,因此分享给大家做个参考,文中示例代码介绍的很详细,感兴趣的朋友接下来一起跟随小编学习一下吧。
这篇文章主要给大家分享的是JavaScript中for循环的内容,对于for循环大家应该都是比较熟悉的吧,下面小编给大家总结了JavaScript中的三种for循环语句使用,对新手学习和理解for循环有一定的帮助,感兴趣的朋友就继续往下看吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008