WebAssembly 是什么?
简单来说,WebAsembly(wasm)为 C/C++、Rust 等其他编程语言参与到 Web 开发提供了一种可行的方式。关于 WebAssembly 的详细介绍请参考 MDN 的 WebAssembly 文档

# 一个简单示例

# 使用纯 JavaScript 代码

function loop(n){ // 一个空循环函数
    for(let i=0; i<n; i++){}
  }
  console.time("测试 loop函数 执行时间: ")
  let result = loop(100_000_000_000) // 执行 1 千亿次循环
  console.timeEnd("测试 loop函数 执行时间: ")
JavaScript代码执行时间

js代码执行时间


# 使用 wasm 的方式

使用 WasmExplorer 可以在线将 C/C++代码 转为 wasm代码
下载转换后的 wasm文件 并命名为 loop.wasm

WasmExplorer

c/c++转换为wasm

然后可以通过浏览器全局对象 WebAssembly 提供的 JavaScript API 进行调用

fetch('./loop.wasm').then(response => 
      response.arrayBuffer() // 抓去 loop.wasm 文件将其转为字节数组,并使用 Promise 返回
    ).then(bytes =>
      WebAssembly.compile(bytes) // 使用 WebAssembly 提供的 compile 方法,将上一步的字节数组编译成模版(Module),并使用 Promise 返回
    ).then(mod => {
      const instance  = new WebAssembly.Instance(mod) // 使用 Module 创建一个 WebAssembly 实例
      const methods = instance.exports
      // console.log(methods)
      console.time("测试 loop函数 执行时间: ")
      let result = methods._Z4loopi(100_000_000_000) // 一千亿次循环
      console.timeEnd("测试 loop函数 执行时间: ")
    });
wasm执行时间

wasm执行时间

# 总结

  1. 执行相同的代码逻辑,使用 WebAssembly 方式的执行时间明显要比使用纯 javascript 方式的执行时间要短不少。
  2. 对于一些计算量大的代码逻辑或者处理时间较长的代码逻辑,使用 WebAssembly 方式会比使用纯 javascript 方式更具有时间和性能上的优势。
  3. 同时 WebAssembly 起到了类似于 Java虚拟机 的作用,有利于跨平台应用开发。
更新于 阅读次数