C/C++编译成.wasm文件,并使用javascript调用接口

本文介绍了如何利用WebAssembly Studio将C/C++代码编译为.wasm文件,并在JavaScript中加载和调用接口。首先,删除不必要的main.js和main.html,然后在C代码中添加函数声明。通过修改输入输出文件名并保存,即可编译生成.wasm。接着,下载生成的.wasm文件并在JavaScript中进行测试,如果遇到问题,可能需要调整加载方式。
摘要由CSDN通过智能技术生成

一、C/C++编译成.wasm

0.背景

准备好本地编译环境Emscripten,使用emcc命令编译的.wasm文件在js里面调用时报这个错误:

CompileError: Wasm decoding failedResult = expected magic word 00 61 73 6d, found 42 43 c0 ……

没找到处理办法,但是找到了一种更简单的方法–使用WebAssembly Studio在线编译。

1、如果只是需要一个.wasm文件,创建Empty C Project

在这里插入图片描述

2、main.js和main.html也可以删除

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-DYrmhl1D-1590498410522)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\1590496699150.png)]

3、在main.c中编写c代码,注意每一个函数上面需要加WASM_EXPORT

在这里插入图片描述

4、可以右键edit更改输入、输出文件名称,但是注意build.ts文件输入、输出文件需要同步

在这里插入图片描述
在这里插入图片描述

5、最后注意保存文件!再build就编译生成了.wasm文件

在这里插入图片描述
在这里插入图片描述

二、javascript加载.wasm文件,调用接口

1、右键刚刚生成的.wasm文件download下载

在这里插入图片描述

2、测试代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8"
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值