分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > IT知识

对于WebAssembly编译出来的.wasm文件js如何调用

发布时间:2023-09-06 02:20责任编辑:赖小花关键词:jsWeb编译

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

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

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

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

c代码

1 int add (int x, int y) {2 ??return x + y;3 }4 5 int square (int x) {6 ??return x * x;7 }

属性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加入调用的方法如下:

 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 ????<meta charset="UTF-8"> 5 ????<meta name="viewport" content="width=device-width, initial-scale=1.0"> 6 ????<meta http-equiv="X-UA-Compatible" content="ie=edge"> 7 ????<title>Document</title> 8 </head> 9 <body>10 ????<h1>11 12 ????</h1>13 ????<script> ???14 ????/**15 ?* @param {String} path wasm 文件路径16 ?* @param {Object} imports 传递到 wasm 代码中的变量17 ?*/18 ????????function loadWebAssembly (path, imports = {}) {19 ??????????return fetch(path) // 加载文件 20 ????????????.then(response => response.arrayBuffer()) // 转成 ArrayBuffer21 ????????????.then(buffer => WebAssembly.compile(buffer))22 ????????????.then(module => {23 ??????????????imports.env = imports.env || {}24 25 ??????????????// 开辟内存空间26 ??????????????imports.env.memoryBase = imports.env.memoryBase || 027 ??????????????if (!imports.env.memory) {28 ????????????????imports.env.memory = new WebAssembly.Memory({ initial: 256 })29 ??????????????}30 31 ??????????????// 创建变量映射表32 ??????????????imports.env.tableBase = imports.env.tableBase || 033 ??????????????if (!imports.env.table) {34 ????????????????// 在 MVP 版本中 element 只能是 "anyfunc"35 ????????????????imports.env.table = new WebAssembly.Table({ initial: 0, element: ‘anyfunc‘ })36 ??????????????}37 38 ??????????????// 创建 WebAssembly 实例39 ??????????????return new WebAssembly.Instance(module, imports)40 ????????????})41 ????????}42 ????????//调用43 ????????loadWebAssembly(‘./math.wasm‘)44 ????????.then(instance => {45 ????????????const add = instance.exports._add//取出c里面的方法46 ????????????const square = instance.exports._square//取出c里面的方法47 48 ????????????console.log(‘10 + 20 =‘, add(10, 20))49 ????????????console.log(‘3*3 =‘, square(3))50 ????????????console.log(‘(2 + 5)*2 =‘, square(add(2 + 5)))51 ????????})52 ????????53 ????</script>54 </body>55 </html>

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

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

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

下载web服务器

然后server . 启动

有点的 .

启动完成效果:

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

对于WebAssembly编译出来的.wasm文件js如何调用

原文地址:https://www.cnblogs.com/y-y-y-y/p/9897154.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved