实验进行中:.NET WebAssembly支持

目前四大主流浏览器都默认支持WebAssembly,而.NET社区也在继续推动为.NET开发者提供相关能力,来将他们的代码编译成WebAssembly,然后在浏览器上运行。

\\

WebAssembly是一种二进制web格式,旨在以接近原生的性能运行不是用JavaScript语言编写的应用。目前,C、C++和Rust都可以通过基于LLVM的工具链来编译成wasm格式。这些语言编译成原生代码,然后可以在没有任何附加代码的情况下运行。当然,.NET通常需要一个运行时平台来执行代码,因此在浏览器中使用它在理论上是可行的,只是需要一些额外的工作来让它更高效地运行。

\\

其中一个非常可能实现.NET WebAssembly的项目,是被Steve Sanderson称作Blazor的项目,虽然它还只是一个进行中的实验,远远没有生产价值。Blazor在Mono运行时平台上,运行被编译成wasdm格式的.NET代码。目前,这导致一个“Hello World”应用的负载比预期中要大,Sanderson说:

\\
\

自从迁移到Mono运行时平台,新的Blazor应用就变得很庞大(大约4MB)。这是因为Mono上的WASM还没有进行任何无效代码剥离和压缩,并且打包了一个非常大的运行时库。这个运行时库包括许多桌面相关的功能,但这些功能是与web无关的。我期望,一个面向web优化过的生产应用,能够减小到接近300KB的大小。

\
\\

这个项目的混合编译模型,已经在2017年11月1日合并到Mono项目。

\\

另外一种可能适合.NET的方法,类似于现有的原生代码编译方法,即静态编译组合成wasm的代码。这些代码包括Mono C 运行时平台和开发者的.NET代码。截至本文撰写时,一个使用这种方式的样本应用,会向用户计算机下载10MB代码。相比之下,加载一次最近的Twitter.com完整页面会下载超过7MB的内容,而访问一次最近的Amazon.com会下载8.9MB的内容。据Miguel de Icaza所说,这个大小应该会随着时间推移而减少:

\\
\

一旦我们使用一种定制的概要文件,这个大小应该会明显减少。这种定制的概要文件基于移动端的概要配置文件,并且移除了许多不必要的功能。

\
\\

这个项目采用“基于LLVM的实验性的WebAssembly,LLVM连接器和二进制化工具来生成最终的.wasm代码”,但是在最近几个月还没有更新过。

\\

在官方的CoreRT库中,也有WebAssembly支持原型。

\\

查看英文原文:.NET WebAssembly Support an Ongoing Experiment

\\

感谢冬雨对本文的审校。

\

给InfoQ中文站投稿或者参与内容翻译工作,请邮件至editors@cn.infoq.com。也欢迎大家通过新浪微博(@InfoQ@丁晓昀),微信(微信号:InfoQChina)关注我们。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值