4

WebAssembly定义

WebAssembly是一种的语言,可以在现代浏览器环境中运行,并提供了功能和性能上的优势。可以将其它语言,如C/C++等,编译成Assembly格式的代码,然后在浏览器中运行。

WebAssembly的目标

  • WebAssembly代码可以获得非常快的运行速度。

  • 增加可读性,WebAssembly还有可读的文本格式,易于编写,调试和阅读。

  • WebAssembly具有非常高安全性,它在一个沙箱环境中执行,同时遵守浏览器的同源策略和权限规则。

  • 和其它Web语言有很好的兼容性

WebAssembly工作原理

Web平台有两不分组成组成:a)执行应用程序的虚拟机,b)Web API,例如(DOM,WebGL等)。为了让浏览器支持Assembly,虚拟机实现了加载两种语言(javascript,Assembly)的功能,javascript可以同过Web API引入WebAssembly代码,WebAssembly可以导入和异步执行javascript的模块。

WebAssembly的关键部分概览

  • module:表示由浏览器编译为可执行机器代码的WebAssembly二进制文件。 对于一个模块是无状态的,因此,像Blob一样,可以显式缓存在IndexedDB中,也可以在windows和worker之间共享(通过postMessage())。 A模块像ES2015模块一样声明导入和导出。

  • Memory:一个可调整大小的ArrayBuffer,它包含可以被WebAssembly的低级内存访问指令读取和写入的线性字节数组。

  • Table:一种引用类型的可变素组(例如函数),无法将其作为原始字节存储在存储器中。

  • Instance:module,Memory,Table等得运行实例

一个C++程序转化为Assembly的例子

图片描述

#include <stdio.h>

int main() {
  printf("hello, world!\n");
  return 0;
}
  • 将C++命名,此处命名为hello.c,然后编译输出html代码,编译命令如下:

emcc hello.c -s WASM=1 -o hello.html

编译输出文件如下:

`hello.html
hello.js
hello.js.temp.js`

  • 用浏览器打开hello.html,即可查看效果


treeandgrass
1.3k 声望16 粉丝

github:[链接]


下一篇 »
FileReader基础