WebAssembly能不能取代JavaScript?15张卡通图给你答案!

一切能用JavaScript实现的,终将用JavaScript实现。

一切能编译为WebAssembly的,终将编译为WebAssembly。

前端er们,WebAssembly用上了吗?在浏览器中快速运行非JavaScript语言,比如C、C++、Rust,是不是很香?今天,我们就来用15张小画图说WebAssembly

有必要先介绍一下小画的创作者。她叫Lin Clark,曾是Mozilla公司的首席研究工程师,精通WebAssembly和Rust。值得一提的是,她的母亲曾为阿波罗登月任务编写汇编语言。如今,Lin是WebAssembly社区响当当的人物,是不是有传承那味儿了?

WebAssembly能做什么?

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第1张图片

有了WebAssembly,JavaScript不再是浏览器端的唯一语言。WebAssembly让你能够在网页中快速运行C、C++、Rust等。

再见JavaScript?

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第2张图片

WebAssembly并不是要取代JavaScript,二者绝非水火不容。实际上,许多应用程序同时使用WebAssembly和JavaScript。不过,如果硬要对比二者的速度,那么WebAssembly显然是增强型。

JavaScript的性能瓶颈在哪里?

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第3张图片

JavaScript的一些根本特性使它速度受限,比如动态类型。直到2008年,JIT(即时编译器)出现,才让JavaScript的性能有了飞跃式提升。

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第4张图片

性能提升使得JavaScript开始被用于服务器端。WebAssembly的出现有望使性能曲线再次实现飞跃。

时间都去哪儿了?

JIT出现之前,JavaScript花在各任务上的相对时长是这样的。

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第5张图片

有了JIT,JavaScript花在各任务上的相对时长变成了这样。

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第6张图片

相比之下,WebAssembly竟然是这样的!

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第7张图片

如何让计算机听我发号施令?

想象有机星人来到地球,你被派去和机星人谈判。要怎么交流呢?

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第8张图片

你或许需要一位口译官,抑或需要一位笔译官。

口译官可以当场逐字逐句地翻译,这其实就是解释器所做的事情。

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第9张图片

笔译官则会将内容写下来,让双方自己理解。这其实就是编译器所做的事情。

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第10张图片

解释器刚运行起来时速度较快,但是效率不高,因为同样的代码可能需要重复解释。编译器则恰恰相反。正因为两者各有千秋,所以JIT结合了二者各自的优势。

那么,WebAssembly是如何做到与机星人交流的呢?我们来分析一下机星人的大脑构成。

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第11张图片

  • ALU是算术逻辑单元,相当于机星人大脑负责思考的部分。

  • register是寄存器,相当于机星人大脑的短时记忆区。

  • RAM是内存,相当于机星人大脑的长期记忆区。

如果给机星人发送二进制指令,它就会这样解读。

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第12张图片

问题是,机星人的大脑构造可能不一样,比如既有可能是x86结构,又有可能是ARM结构。而我们也会使用不同的语言,比如C、C++或者Rust。要两两匹配地进行翻译,工作量实在太大!

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第13张图片

为此,人们增加了IR,即中间表示。编译器的前端先将高级语言变成IR,编译器的后端则负责将IR变成汇编码。

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第14张图片

那么,WebAssembly的位置在哪里呢?

每一类计算机处理器都有自己的机器码类型。在取得IR代码后,通过一个专门的编译器来运行,这个编译器将IR代码转换为一种专用字节码并放入后缀为.wasm的文件中。

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第15张图片

.wasm文件中的字节码还不是机器码,它只是支持WebAssembly的浏览器能够理解的一组虚拟指令。当加载到支持WebAssembly的浏览器中时,浏览器会验证该文件的合法性,然后这些字节码会继续编译为机器码。

如今,各大主流浏览器都已支持WebAssembly。现在就尝试使用WebAssembly吧!

本文中的插图由Lin Clark创作,源网址如下:

https://hacks.mozilla.org/2017/02/a-cartoon-intro-to-webassembly/

本文对插图的使用经Lin Clark同意,且遵守CC BY-SA 3.0协议。

https://creativecommons.org/licenses/by-sa/3.0/

今 日 荐 书

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第16张图片

C. 杰勒德•加伦特 著
单业 译

想在浏览器中使用非JavaScript语言?
WebAssembly帮你做到!

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第17张图片


留 言 赠 书

你比较看好哪些前端技术?为什么?

图灵君将挑选2位幸运同学,各送出《WebAssembly实战》1册。

6月18日开奖~

618图灵直播已开启

就等你来!

6月16日:腾讯专家讲小程序开发

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第18张图片

6月17日: 微博大佬讲信息安全

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第19张图片

感兴趣的同学记得扫码预约报名哦,

直播有好书相送!!!

图 灵 社 群

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第20张图片

WebAssembly能不能取代JavaScript?15张卡通图给你答案!_第21张图片

喜欢这篇文章?点个“在看”吧~▼

你可能感兴趣的:(编译器,编程语言,css3,javascript,js)