小册上新 | 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、小爱音箱等十几种礼物等你来拿~

相关推荐
翻滚吧键盘12 分钟前
{{ }}和v-on:click
前端·vue.js
上单带刀不带妹18 分钟前
手写 Vue 中虚拟 DOM 到真实 DOM 的完整过程
开发语言·前端·javascript·vue.js·前端框架
前端风云志21 分钟前
typescript结构化类型应用两例
javascript
杨进军39 分钟前
React 创建根节点 createRoot
前端·react.js·前端框架
ModyQyW1 小时前
用 AI 驱动 wot-design-uni 开发小程序
前端·uni-app
说码解字1 小时前
Kotlin lazy 委托的底层实现原理
前端
gnip1 小时前
总结一期正则表达式
javascript·正则表达式
爱分享的程序员2 小时前
前端面试专栏-算法篇:18. 查找算法(二分查找、哈希查找)
前端·javascript·node.js
翻滚吧键盘2 小时前
vue 条件渲染(v-if v-else-if v-else v-show)
前端·javascript·vue.js
vim怎么退出2 小时前
万字长文带你了解微前端架构
前端·微服务·前端框架