JavaScript的运行原理

JavaScript代码的执行

◼ JavaScript代码下载好之后,是如何一步步被执行的呢?
◼ 我们知道,浏览器内核是由两部分组成的,以webkit为例:
    WebCore:负责HTML解析、布局、渲染等等相关的工作;
    JavaScriptCore:解析、执行JavaScript代码;
                  WebKit
                    |
        --------------------------
        |                        |
    WebCore                 JavaScriptCore
◼ 另外一个强大的JavaScript引擎就是V8引擎。

深入V8引擎原理

◼ 我们来看一下官方对V8引擎的定义:
  V8是用C ++编写的Google开源高性能JavaScript和WebAssembly引擎,它用于Chrome和Node.js等。
  它实现ECMAScript和WebAssembly,并在Windows 7或更高版本,macOS 10.12+和使用x64,IA-32,ARM或MIPS处理器的Linux系统上运行。
  V8可以独立运行,也可以嵌入到任何C ++应用程序中。

V8引擎的架构

◼ V8引擎本身的源码非常复杂,大概有超过100w行C++代码,通过了解它的架构,我们可以知道它是如何对JavaScript执行的:
◼ Parse模块会将JavaScript代码转换成AST(抽象语法树),这是因为解释器并不直接认识JavaScript代码;
  如果函数没有被调用,那么是不会被转换成AST的;
  Parse的V8官方文档:https://v8.dev/blog/scanner
◼ Ignition是一个解释器,会将AST转换成ByteCode(字节码)
  同时会收集TurboFan优化所需要的信息(比如函数参数的类型信息,有了类型才能进行真实的运算);
  如果函数只调用一次,Ignition会解释执行ByteCode;
  Ignition的V8官方文档:https://v8.dev/blog/ignition-interpreter
◼ TurboFan是一个编译器,可以将字节码编译为CPU可以直接执行的机器码;
  如果一个函数被多次调用,那么就会被标记为热点函数,那么就会经过TurboFan转换成优化的机器码,提高代码的执行性能;
  但是,机器码实际上也会被还原为ByteCode,这是因为如果后续执行函数的过程中,类型发生了变化(比如sum函数原来执行的是number类型,后来执行变成了string类型),之前优化的机器码并不能正确的处理运算,就会逆向的转换成字节码;
  TurboFan的V8官方文档:https://v8.dev/blog/turbofan-jit

JavaScript源码--->parse模块--->转化为AST(抽象语法树)--->lgnition解释器------------------>ByteCode字节码------>执行
                                                            |                                |
                                                            |                                |
                                                            |                                |
                                                        TurboFan编译器----->优化机械码--->     |
                                                                                      数据类型发生改变
posted @ 2024-10-20 00:52  韩德才  阅读(6)  评论(0编辑  收藏  举报