百科狗-知识改变命运!
--

WebAssembly - JavaScript WebAssembly 对象

百变鹏仔1年前 (2023-11-21)阅读数 20#技术干货
文章标签对象

WebAssembly

WebAssemblyJavaScript 对象是所有 WebAssembly 相关功能的命名空间。

和大多数全局对象不一样,WebAssembly不是一个构造函数(它不是一个函数对象)。它类似于Intl对象,Math 对象也是一个命名空间对象,用于保存数学常量和函数;Intl则是用于国际化和其他语言相关函数的命名空间对象。

描述

WebAssembly对象主要用于:

  • 使用WebAssembly.instantiate()函数加载 WebAssembly 代码。
  • 通过WebAssembly.Table()构造函数创建新的内存和表实例。
  • WebAssembly.RuntimeError()构造函数来提供 WebAssembly 中的错误信息。

方法

WebAssembly.instantiate()用于编译和实例化 WebAssembly 代码的主 API,返回一个 Module 和它的第一个实例。WebAssembly.instantiateStreaming()直接从流式底层源编译和实例化WebAssembly模块,同时返回Module及其第一个实例。WebAssembly.compile()把 WebAssembly 二进制代码编译为一个WebAssembly.Module,不进行实例化。WebAssembly.compileStreaming()直接从流式底层源代码编译WebAssembly.Module,将实例化作为一个单独的步骤。WebAssembly.validate()校验 WebAssembly 二进制代码的类型数组是否合法,合法则返回 true ,否则返回 false 。

构造器

WebAssembly.Module()创建一个新的WebAssembly模块对象。WebAssembly.Instance()创建一个新的WebAssembly实例对象。WebAssembly.Memory()创建一个新的WebAssembly内存对象。WebAssembly.Table()创建一个新的WebAssembly表格对象。WebAssembly.CompileError()创建一个新的WebAssembly编译错误对象。WebAssembly.LinkError()创建一个新的WebAssembly链接错误对象。WebAssembly.RuntimeError()创建一个新的WebAssembly运行时错误对象。

示例

通过fetch方法获取了WebAssembly字节码后,我们通过WebAssembly.instantiate()方法对模块进行编译和实例化,在这过程中将一个JavaScript 函数导入WebAssembly模块。这个promise实例解析成一个对象(result),result包含编译了的ModuleInstance对象。接下来我们调用一个Instance导出的WebAssembly方法。

var importObject = {
  imports: {
    imported_func: function(arg) {
      console.log(arg);
    }
  }
};

fetch('simple.wasm').then(response =>
  response.arrayBuffer()
).then(bytes =>
  WebAssembly.instantiate(bytes, importObject)
).then(result =>
  result.instance.exports.exported_func()
);

WebAssembly - JavaScript WebAssembly 对象

注意:有关使用了我们fetchAndInstantiate()库函数的示例,请查看Github上的 index.html(或者查看在线示例)。

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)