小册上新 | QuickJS 引擎源码解析与实践

也许你还不知道 QuickJS 是什么,但你肯定听说过 V8 引擎。

V8 引擎是当今主流的 JavaScript 引擎(JS 引擎)之一,相比 V8 这类引擎动辄百万行的代码量,QuickJS 仅通过约 5.4 万 C 代码就达到了与之相媲美的完成度。

比如,从下图 QuickJS、V8、JSC 等引擎执行 Test262 的情况中,我们就能看出,QuickJS 与主流引擎对 ECMAScript 标准的支持度是差不多的。

QuickJS、v8、JSC 等引擎执行 Test262 的结果对比

那么, QuickJS是什么呢?

QuickJS 是由 Fabrice Bellard 编写的 JS 引擎,具有启动速度快、执行效率高、运行功耗低,支持 ES2020 等特点,被 Microsoft、Google、Intel 等知名公司在 FuchsiaCCFWasmnizer-ts 等项目中使用。

如果你正在寻找一个体积小且优秀的 JS 引擎,也许 QuickJS 将是一个合适的选择。当然,如果你已经很了解,或是在工作中用过 QuickJS,那一定已经知道它的优秀之处了。同时,如果你正想深入研究 JS 引擎,也建议从 QuickJS 入手。

无论是想要用好 QuickJS,还是深入研究 JS 引擎,都离不开对源码层面的研究和学习。

那在这本小册中,我们会通过分析 QuickJS 引擎的源码,向大家展示 JavaScript 引擎的核心工作原理,整体运行过程,带大家了解 QuickJS 内部实现,入门引擎学习

上面的思维导图已经比较清晰了,仅有两点需要突出介绍。

第一点,我们会先学习指令的执行,再学习指令的生成。这是因为,引擎的首要任务是完成用户编写的计算任务。直接编写字节码在理论上也是可行的,能够接收使用 JS 编写的计算任务是为了方便开发者而提供的编程接口。

第二点,「好之者不如乐之者」,我们不仅局限于源码解析,最后还会进行两个小型实践,一起为引擎增加 2 个新的实用功能,体验一把开发引擎的乐趣。

言而总之,学习 JS 引擎是有趣的,选择 QuickJS 着手是有效的。事不宜迟,让我们即刻出发吧!

适宜人群

不为无益之事,何以遣有涯之生。对于引擎实现的学习,可能很长时间内是无法变现的,因此它或许成了部分人眼中的「无益」之事。如果考虑这样的情况,那么对引擎实现感兴趣无疑是本课程最适宜的人群。

除了兴趣之外,还需要几点要求并不高的编程经验:

  • 可以熟练地使用 JavaScript 编写程序,接触过 TypeScript
  • 使用 C 语言至少编写并成功运行过 Hello World 程序
  • 使用过任意的 Linux 发行版、macOS、WSL

要求并不高的意思是,即使在阅读小册之前没有这些经验,利用网络准备起来也很快。

你将获得

  • 编译运行结合源码调试,高效理解 QuickJS 源码;
  • 原型虚拟机+解释器实现,一起搞懂 JS 指令关键原理;
  • 2 个实用功能,深度体验 QuickJS "过人"之处;
  • 运行过程+关键环节梳理,入门 JS 引擎学习。

6 折特惠,还能叠加 1024 满赠,快来看看吧~

1024活动指路👉🏻:💥1024最强省钱攻略 | 全场小册5折起,更有小米手环 7Pro、小爱音箱等十几种礼物等你来拿~

相关推荐
奋斗的小羊羊27 分钟前
HTML5关键知识点之多种视频编码工具的使用方法
前端·音视频·html5
前端呆猿34 分钟前
深入解析HTML5中的object-fit属性
前端·css·html5
再学一点就睡34 分钟前
实现大文件上传全流程详解(补偿版本)
前端·javascript·面试
你的人类朋友2 小时前
【Node&Vue】什么是ECMAScript?
前端·javascript·后端
路灯下的光2 小时前
用scss设计一下系统主题有什么方案吗
前端·css·scss
l_tian_tian_2 小时前
SpringClound——网关、服务保护和分布式事务
linux·服务器·前端
一只小风华~3 小时前
CSS @media 媒体查询
前端·css·媒体
shix .3 小时前
最近 | 黄淮教务 | 小工具合集
前端·javascript
John_ToDebug4 小时前
Chrome 内置扩展 vs WebUI:浏览器内核开发中的选择与实践
前端·c++·chrome
烛阴4 小时前
解锁动态键:TypeScript 索引签名完全指南
前端·javascript·typescript