带你了解JavaScript的运行原理_基础知识

来源:脚本之家  责任编辑:小易  
目录
浏览器内核JavaScript 引擎V8 引擎

了解JavaScript 是如何运行的,以及的它的运行机制,首先,我们要了解浏览器的内核:

浏览器内核

了解过的都知道:不同的浏览器是由不同的内核组成,那么有哪些内核以及我们常用的浏览器都使用了那些内核:

Gecko:早期被Netscape和Mozilla Firefox浏览器浏览器使用; Trident:微软开发,被IE4~IE11浏览器使用,但是Edge浏览器已经转向Blink; Webkit:苹果基于KHTML开发、开源的,用于Safari,Google Chrome之前也在使用; Blink:是Webkit的一个分支,Google开发,目前应用于Google Chrome、Edge、Opera等;

所谓浏览器内核,指的是浏览器的排版引擎,即浏览器引擎。引擎的工作执行流程如下:

在这里插入图片描述

但是在这个执行过程中,HTML解析的时候遇到了JavaScript标签,应该怎么办呢?
会停止解析HTML,而去加载和执行JavaScript代码;

当然,为什么不直接异步去加载执行JavaScript代码,而要在这里停止掉呢?

所以浏览器希望将HTML解析的DOM和JavaScript操作之后的DOM放到一起来生成最终的DOM树,而不是频繁的去生成新的DOM树;

那么,JavaScript代码由谁来执行呢?
答案:JavaScript 引擎

JavaScript 引擎

为什么需要JavaScript引擎呢?

事实上我们编写的JavaScript无论你交给浏览器或者Node执行,最后都是需要被CPU执行的; 但是CPU只认识自己的指令集,实际上是机器语言,才能被CPU所执行; 所以我们需要JavaScript引擎帮助我们将JavaScript代码翻译成CPU指令来执行;

常见的JavaScript 引擎有哪些呢?

SpiderMonkey:第一款JavaScript引擎,由Brendan Eich开发(也就是JavaScript作者); Chakra:微软开发,用于IE浏览器; JavaScriptCore:WebKit中的JavaScript引擎,Apple公司开发; V8:Google开发的强大JavaScript引擎,也帮助Chrome从众多浏览器中脱颖而出;(V8 是一个强大的JavaScript 引擎)

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 引擎执行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代码的执行过程

学习,记录,共勉!

到此这篇关于带你了解JavaScript的运行原理的文章就介绍到这了,更多相关JavaScript运行原理内容请搜索真格学网以前的文章或继续浏览下面的相关文章希望大家以后多多支持真格学网!

您可能感兴趣的文章:JavaScript运行原理分析javascript运行机制之执行顺序理解JavaScript运行机制实例分析JavaScript运行机制之事件循环(Event Loop)详解javascript运行机制之this详细介绍

  • 本文相关:
  • js 使用form表单select类实现级联菜单效果
  • javascript object 对象学习笔记
  • 再探javascript作用域
  • 使用javascipt---实现二分查找法
  • javascipt基本教程之javascript语言的基础
  • javascript静态类型检查工具flow简介
  • javascript中的tolocalelowercase()方法使用详解
  • 兼容mozilla必须知道的知识。
  • javascript之typeof、instanceof操作符使用探讨
  • javascript进阶教程(第一课)
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全基础知识javascript类库表单特效广告代码网页特效黑客性质javascript技巧domnode.jsjs其它首页javascript基础知识javascript运行原理分析javascript运行机制之执行顺序理解javascript运行机制实例分析javascript运行机制之事件循环(event loop)详解javascript运行机制之this详细介绍js 使用form表单select类实现级联菜单效果javascript object 对象学习笔记再探javascript作用域使用javascipt---实现二分查找法javascipt基本教程之javascript语言的基础javascript静态类型检查工具flow简介javascript中的tolocalelowercase()方法使用详解兼容mozilla必须知道的知识。javascript之typeof、instanceof操作符使用探讨javascript进阶教程(第一课)js split 的用法和定义 js splitwindow.location.href的用法(动态js 小数取整的函数javascript中判断两个字符串是否js array 数组详解向javascript的数组中添加元素的基于javascript 声明全局变量的三javascript math ceil()、floor(html复选框和单选框 checkbox和rjavascript window.settimeout()javascript的原生方法获取数组中的最大(最在javascript中操作时间之setyear()方法的浅谈javascript中的作用域和闭包问题javascript浅谈之this基于js脚本语言的基础语法详解js取0-9随机取4个数不重复的数字代码实例javascript入门学习书籍推荐javascript学习笔记之js函数javascript图像处理—亮度对比度应用案例浅谈js基本数据类型和typeof
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved