JS如何调用wasm

1.生成wasm文件
javascript 复制代码
const fs = require("fs");
const wabt = require("wabt")(); // 注意 () 表示初始化

(async () => {
  const wabtModule = await wabt;

  const wat = `
(module
  (func (export "add") (param i32 i32) (result i32)
    local.get 0
    local.get 1
    i32.add)
  )
`;

  // 把 WAT 转换成二进制 WASM
  const parsed = wabtModule.parseWat("add.wat", wat);
  const { buffer } = parsed.toBinary({});

  fs.writeFileSync("add.wasm", Buffer.from(buffer));
  console.log("✅ 已生成 add.wasm");
})();
2.JavaScript 调用wasm文件
javascript 复制代码
const fs = require("fs");

async function init() {
  // 1. 读取 .wasm 文件
  const bytes = fs.readFileSync("add.wasm");

  // 2. 编译并实例化
  const { instance } = await WebAssembly.instantiate(bytes);

  // 3. 调用导出的函数
  console.log("2 + 3 =", instance.exports.add(2, 3));
}

init();
3.wasm调用JavaScript

在实例化传入importObject

javascript 复制代码
const fs = require("fs");
const wabt = require("wabt"); // 确保已安装:npm install wabt

// 完整的异步执行函数
async function runWasm() {
  // 1. 初始化 wabt(关键:2.x+ 版本返回的是对象,需解构出 parseWat)
  const { parseWat } = await wabt();

  // 2. 定义 WAT 文本(WebAssembly 文本格式)
  const wat = `
    (module
      ;; 导入 env.log 函数(接收 i32 参数)
      (import "env" "log" (func $log (param i32)))
      ;; 导出 run 函数(供 JS 调用)
      (func (export "run")
        i32.const 42  ;; 压入常量 42 到栈
        call $log     ;; 调用导入的 log 函数
      )
    )
  `;

  // 3. 转换 WAT -> 二进制 WASM(修复核心:用解构出的 parseWat 函数)
  const parsed = parseWat("module.wat", wat, {
    // 可选配置:启用 WebAssembly 标准特性
    exceptions: false,
    mutable_globals: true,
    sat_float_to_int: true,
    sign_extension: true,
  });

  // 4. 生成 WASM 二进制文件
  const { buffer } = parsed.toBinary({});
  fs.writeFileSync("module.wasm", Buffer.from(buffer));
  console.log("✅ module.wasm 已生成");

  // 5. 定义导入对象(给 WASM 提供 JS 环境的函数)
  const importObject = {
    env: {
      log: (num) => console.log("WASM 调用 log 函数:", num),
    },
  };

  // 6. 读取 WASM 二进制并实例化
  const wasmBytes = fs.readFileSync("module.wasm");
  const { instance } = await WebAssembly.instantiate(wasmBytes, importObject);

  // 7. 调用 WASM 导出的 run 函数
  instance.exports.run(); // 输出:WASM 调用 log 函数: 42
}

// 执行函数并捕获错误
runWasm().catch((err) => {
  console.error("执行失败:", err);
});
相关推荐
为何创造硅基生物4 小时前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言
吃好睡好便好4 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
星寂樱易李4 小时前
iperf3 + Python-- 网络带宽、网速、网络稳定性
开发语言·网络·python
仰泳之鹅4 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
之歆4 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
Maimai108085 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
candyTong5 小时前
Claude Code 的 Edit 工具是怎么工作的
javascript·后端·架构
cen__y6 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
AI人工智能+电脑小能手6 小时前
【大白话说Java面试题 第65题】【JVM篇】第25题:谈谈对 OOM 的认识
java·开发语言·jvm
社交怪人6 小时前
【算平均分】信息学奥赛一本通C语言解法(题号2071)
c语言·开发语言