JS如何调用WebAssembly编译出来的.wasm文件


Posted in Javascript onNovember 05, 2020

WebAssembly也叫浏览器字节码技术 这里就不过多的解释了网上很多介绍

主要是让大家知道在js里面如何调用执行它,我之前看WebAssemblyAPI时候反正是看得一脸懵逼

也是为了大家能更快的入手这个比较新的技术吧

这边写的一个dom是官方推荐的c/c++编译的

c代码

int add (int x, int y) {
 return x + y;
 }
 
 int square (int x) {
 return x * x;
 }

属性c但是对字节码不熟悉的朋友可能会不理解,为什么没有main函数

这里主要是把这个c代码当成一个模块调用不需要它自己执行所以没有,官方也有有main函数的能直接生成js和html但是太过雍于,

这种方式比较推荐,也是让js能直接调用比较方便

之后使用 emscripten进行编译 emcc math.c -Os -s WASM=1 -s SIDE_MODULE=1 -o math.wasm

然后就有math.wasm文件了,如果没装emscripten的话我博客里面有一篇是关于安装的

有了math.wasm文件后就该用js调用它了

新建math.html加入调用的方法如下:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>Document</title>
</head>
<body>
 <h1>

 </h1>
 <script>
 /**
 * @param {String} path wasm 文件路径
 * @param {Object} imports 传递到 wasm 代码中的变量
 */
  function loadWebAssembly (path, imports = {}) {
   return fetch(path) // 加载文件
   .then(response => response.arrayBuffer()) // 转成 ArrayBuffer
   .then(buffer => WebAssembly.compile(buffer))
   .then(module => {
    imports.env = imports.env || {}

    // 开辟内存空间
    imports.env.memoryBase = imports.env.memoryBase || 0
    if (!imports.env.memory) {
    imports.env.memory = new WebAssembly.Memory({ initial: 256 })
    }

    // 创建变量映射表
    imports.env.tableBase = imports.env.tableBase || 0
    if (!imports.env.table) {
    // 在 MVP 版本中 element 只能是 "anyfunc"
    imports.env.table = new WebAssembly.Table({ initial: 0, element: 'anyfunc' })
    }

    // 创建 WebAssembly 实例
    return new WebAssembly.Instance(module, imports)
   })
  }
  //调用
  loadWebAssembly('./math.wasm')
  .then(instance => {
   const add = instance.exports._add//取出c里面的方法
   const square = instance.exports._square//取出c里面的方法

   console.log('10 + 20 =', add(10, 20))
   console.log('3*3 =', square(3))
   console.log('(2 + 5)*2 =', square(add(2 + 5)))
  })

 </script>
</body>
</html>

我这里的路径math.html和math.wasm是同级的

现在就可以打开浏览器查看了 但是fetch方法在本地是不能使用的它是网络请求 所有这里需要来个web服务器

打开终端之间键入 npm install -g serve

下载web服务器

然后serve . 启动

有点的 .

启动完成效果:

JS如何调用WebAssembly编译出来的.wasm文件

然后通过web服务器访问就能看到调用c方法后的计算结果:

JS如何调用WebAssembly编译出来的.wasm文件

到此这篇关于关于WebAssembly编译出来的.wasm文件js如何调用的文章就介绍到这了,更多相关js调用.wasm文件内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
Javascript 写的简单进度条控件
Jan 22 Javascript
使用JavaScript和C#中获得referer
Nov 14 Javascript
Javascript基础教程之for循环
Jan 18 Javascript
JavaScript获得表单target属性的方法
Apr 02 Javascript
js 获取当前web应用的上下文路径实现方法
Aug 19 Javascript
JavaScript之filter_动力节点Java学院整理
Jun 28 Javascript
JS中的多态实例详解
Oct 15 Javascript
vue组件父子间通信之综合练习(聊天室)
Nov 07 Javascript
JS实现的抛物线运动效果示例
Jan 30 Javascript
Angular Excel 导入与导出的实现代码
Apr 17 Javascript
Vue CLI3移动端适配(px2rem或postcss-plugin-px2rem)
Apr 27 Javascript
基于 Vue 的 Electron 项目搭建过程图文详解
Jul 22 Javascript
nuxt.js写项目时增加错误提示页面操作
Nov 05 #Javascript
Vue实现Header渐隐渐现效果的实例代码
Nov 05 #Javascript
Nuxt pages下不同的页面对应layout下的页面布局操作
Nov 05 #Javascript
Vue2.x和Vue3.x的双向绑定原理详解
Nov 05 #Javascript
nuxt引入组件和公共样式的操作
Nov 05 #Javascript
jQuery列表动态增加和删除的实现方法
Nov 05 #jQuery
nuxt 实现在其它js文件中使用store的方式
Nov 05 #Javascript
You might like
php读取二进制流(C语言结构体struct数据文件)的深入解析
2013/06/13 PHP
如何使用PHP获取指定日期所在月的开始日期与结束日期
2013/08/01 PHP
php中mail函数发送邮件失败的解决方法
2014/12/24 PHP
php实现CSV文件导入和导出
2015/10/24 PHP
PHP设计模式(三)建造者模式Builder实例详解【创建型】
2020/05/02 PHP
不间断滚动JS打包类,基本可以实现所有的滚动效果,太强了
2007/12/08 Javascript
JavaScript 编写匿名函数的几种方法
2010/02/21 Javascript
JSQL 批量图片切换的实现代码
2010/05/05 Javascript
基于JQuery 的消息提示框效果代码
2011/07/31 Javascript
jQuery中each()、find()和filter()等节点操作方法详解(推荐)
2016/05/25 Javascript
js自制图片放大镜功能
2017/01/24 Javascript
jquery如何实现点击空白处隐藏元素
2017/12/05 jQuery
vue2.0 自定义 饼状图 (Echarts)组件的方法
2018/03/02 Javascript
微信小程序开发摇一摇功能
2019/11/22 Javascript
JavaScript函数重载操作实例浅析
2020/05/02 Javascript
Openlayers3实现车辆轨迹回放功能
2020/09/29 Javascript
Python编程之字符串模板(Template)用法实例分析
2017/07/22 Python
更改Python的pip install 默认安装依赖路径方法详解
2018/10/27 Python
解决python 未发现数据源名称并且未指定默认驱动程序的问题
2018/12/07 Python
python生成器与迭代器详解
2019/01/01 Python
python实现登录密码重置简易操作代码
2019/08/14 Python
Python Django框架url反向解析实现动态生成对应的url链接示例
2019/10/18 Python
利用Python代码实现一键抠背景功能
2019/12/29 Python
keras Lambda自定义层实现数据的切片方式,Lambda传参数
2020/06/11 Python
Python 使用Opencv实现目标检测与识别的示例代码
2020/09/08 Python
python通过cython加密代码
2020/12/11 Python
美国在线奢侈品寄售商店:Luxury Garage Sale
2018/08/19 全球购物
MYSQL相比于其他数据库有哪些特点
2013/07/19 面试题
旅游管理毕业生自荐信范文
2014/03/19 职场文书
创先争优标语
2014/06/27 职场文书
房屋买卖授权委托书
2014/09/27 职场文书
2015年扶贫帮困工作总结
2015/05/20 职场文书
五一晚会主持词
2015/07/01 职场文书
尊师重教主题班会
2015/08/14 职场文书
mybatis使用oracle进行添加数据的方法
2021/04/27 Oracle
Python序列化与反序列化相关知识总结
2021/06/08 Python