V8引擎如何执行JS代码

1.JS引擎工作流程

以下为v8引擎举例:

说明:

  1. 解析器:将js进行解析和预解析,经过词法分析和语法分析后生成AST树;
复制代码
预解析:将不是立即执行函数的函数进行预解析,对其标记为函数,但不解析函数里面的代码,而对函数的全局解析是在函数被调用时才会进行。
  1. 解释器:将AST树转为字节码,并且执行字节码。执行的过程中会标记热点代码(比如执行多次的函数),会把热点代码的字节码传给编译器进行优化。
  2. 编译器:将热点代码的字节码转为机器指令并缓存下来,等解释器下次执行可以直接执行机器指令提高执行效率。 注意: 优化可以提高代码执行速度,但是某些优化会导致错误,比如当一个函数参数类型发生变化时,之前已经优化过的代码可能会出现类型错误,这时就需要进行逆优化,恢复到未优化的状态。

2.js解析过程和执行过程详细操作

1.js解析过程(Parse阶段) 也就是js->AST Tree过程中

  • 对于全局代码解析情况如下
  • 对于函数代码解析情况如下

3.执行时

将全局执行上下文/函数执行上下文压入到执行上下文栈(Execution Context stack)中,从栈顶开始执行,执行上下文还会生成作用域链(scope chain),当代码执行时取值或赋值操作会在当前的VO进行寻找,寻找不到则会去父作用域的VO寻找,以此往上寻找,直到找到全局执行上下文的VO,若找不到则会报错。

4.执行后

会依次将函数执行上下文进行出栈操作

相关推荐
wjj不想说话1 小时前
你的小程序活动页,可能已经成了后台配置的杂物间
前端
梦想是准点下班1 小时前
androidStudio打包,我又又又忘了
前端
槑有老呆1 小时前
栈队列链表,三个故事就懂了
前端
ViavaCos1 小时前
pnpm v11 的安全策略,让我踩了个坑
前端
To_OC1 小时前
从一段定时器代码,重新捋清 JS 同步、异步与 Promise
前端·javascript·代码规范
持敬chijing1 小时前
Web渗透之前后端漏洞-XSS漏洞原理攻击防御全流程
前端·安全·web安全·网络安全·网络攻击模型·安全威胁分析·xss
程序员黑豆1 小时前
AI全栈开发 - Java:注释
前端·后端·ai编程
痕忆丶2 小时前
Typora 的替代marktext,marktext切换中文
前端
羊羊小栈2 小时前
Uplift营销供应链协同决策系统(基于Uplift因果推断与运筹优化算法)
前端·人工智能·算法·毕业设计·大作业
阿猫的故乡2 小时前
Vue组合式函数(Composables)从入门到实战:鼠标跟踪、请求封装、本地存储……全案例拆解
前端·vue.js·计算机外设