WebAssembly笔记(4)-JavaScript和C++的交互

本文详细介绍了如何实现JavaScript调用C++函数,包括使用EMSCRIPTEN_KEEPALIVE标识导出函数,以及JS如何传参数(如字符串)给C。同时,也讲解了C++如何将参数传递回JavaScript,涉及到内存分配和字符串处理。通过实例代码展示了从编译到运行的完整过程。
摘要由CSDN通过智能技术生成

一 JS调用C++函数

从JS中调用C++函数,需要把C++函数声明为导出,有好几种方法,本文采用最原始也是效率最高的方法,就是函数签名加上 EMSCRIPTEN_KEEPALIVE

1.1 EMSCRIPTEN_KEEPALIVE

作用是告诉C++编译器这个函数会被用到,不要在“tree shaking”的时候删掉,并且会将函数名加上前缀 _ 导出给 JS。另外还需加上 extern "C" 告诉 C++ 编译器不要修改函数名,保留 C 语言的函数名。

// test.c

#include <emscripten.h>  // EMSCRIPTEN_KEEPALIVE

#ifdef __cplusplus
#define EXTERN_C extern "C"
#else
#define EXTERN_C
#endif

EXTERN_C EMSCRIPTEN_KEEPALIVE
int add(int a, int b) {
  return a + b;
}

然后使用 emcc -o test.js test.c 编译,将会生成 test.js 和 test.wasm 两个文件,test.js 的作用是加载 test.wasm。

为了方便在网页中展示结果,再增加一个 test.html 文件,在 html 中去加载 test.js,内容如下。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值