WebAssembly,开发者赢了

自从WebAssembly标准发布以及各大浏览器完成对其默认支持之后,WebAssembly成为前端热门话题。在WebAssembly之前,类似的前端二进制标准有火狐主导的asm.js和Chrome主导的PNaCl。二者均用于将后端C/C++代码用于前端,作为它们折中方案,WebAssembly标准更偏向于asm.js的实现。Chrome在支持了WebAssembly标准之后,宣布将放弃对PNaCl的支持。

作为前端标准,PNaCl在创立之初就有其先天不足。在设计上,PNaCl代码和前端代码(Javascript、HTML等)高度独立,并且PNaCl代码运行在独立进程中,这使得PNaCl代码和页面代码交互成本非常高(需要通过IPC方式)。另外,处于安全考虑,PNaCl进程运行在沙箱环境中,Chrome为此定义了一套API,称为:Pepper。Pepper定义的API中,有许多和现行Web标准重复。

更加严重的问题是,不论是Pepper还是PNaCl,都没有明确的二进制代码规范。因此非Chrome浏览器如果要兼容PNaCl插件,要么反向工程Pepper来自己实现一套接口实现,要么从Chromium工程中导入其中的实现代码。无论哪种方式,都需要和Google的修改同步。这对于开发者来说是不可接受的。

相反,asm.js实现方式从一开始就尽量贴近前端开发和已有前端标准。asm.js用Javascript数组来表示内存,并将C/C++代码编译成Javascript以操作这个数组。这种实现方式相比PNaCl有一个很大的优势:所有代码在同一个JS虚拟机中运行,可以方便的和其他Javascript代码、DOM进行交互。另外,这样的实现没有引入新的API,因此文档相关的工作也比较少。

综上所述,WebAssembly标准最终和asm.js比较接近,它实现在JS虚拟机中,可以和页面Javascript之间方便的进行调用。WebAssembly标准除了新增加载和链接WebAssembly代码相关的API之外,没有定义新的平台相关API。和asm.js不同的是,WebAssembly完整定义了二进制代码规范,相关规范文档已经完成。

当然,Google和其他团队在WebAssembly标准的制定上也功不可没。针对PNaCl插件,Google已经发布了迁移文档。可以说,WebAssembly标准的发布,真正的赢家是开发者!

原文地址:http://www.infoq.com/cn/news/2017/06/WebAssembly-fire-fox-win


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值