0

0

C++如何将项目编译成WebAssembly?Emscripten C++ to WASM教程【Web开发】

穿越時空

穿越時空

发布时间:2025-12-22 16:01:02

|

524人浏览过

|

来源于php中文网

原创

用emscripten编译c++为webassembly需替换g++为em++,安装官方emsdk并配置环境变量,验证emcc/em++版本后即可编译单文件生成wasm及js胶水代码。

c++如何将项目编译成webassembly?emscripten c++ to wasm教程【web开发】

用 Emscripten 把 C++ 项目编译成 WebAssembly 很直接,核心是把 g++ 换成 em++,并注意输出目标和 JS 胶水代码的配合。

安装并配置 Emscripten

Emscripten 是官方推荐的 C/C++ 到 WebAssembly 的工具链。别用 npm 安装的简化版(如 emscripten 包),它不完整。正确方式是:

  • emscripten.org 下载 SDK(推荐使用 emsdk
  • 运行 ./emsdk install latest./emsdk activate latest
  • 执行 source ./emsdk_env.sh(Linux/macOS)或 emsdk_env.bat(Windows)把工具加入环境变量
  • 验证:运行 emcc --versionem++ --version 确保正常

编译单个 C++ 文件为 WASM

最简场景:一个 main.cpp,含 int main()

#include <iostream>
int main() {
    std::cout << "Hello from WebAssembly!\n";
    return 0;
}

运行以下命令:

立即学习C++免费学习笔记(深入)”;

PhotoAid Image Upscaler
PhotoAid Image Upscaler

PhotoAid出品的免费在线AI图片放大工具

下载
em++ main.cpp -o hello.html --no-entry
  • -o hello.html:生成 HTML + JS + WASM 三件套(也可用 .js 只输出 JS 胶水)
  • --no-entry:避免自动生成 main() 入口调用(适合后续手动控制执行)
  • 默认启用 -O2 优化;加 -g 可保留调试信息

生成的 hello.html 可直接用浏览器打开(需本地起服务,如 npx http-server,不能双击打开)。

处理依赖与 CMake 项目

已有 CMake 项目的,只需切换编译器:

  • 设置 EMSCRIPTEN 环境变量指向 SDK 根目录(自动识别)
  • 运行:
    emcmake cmake -B build -S . -DCMAKE_BUILD_TYPE=Release
    cmake --build build
  • emcmake 是封装脚本,会自动配置 CMAKE_CXX_COMPILERem++,并传入必要 flags
  • 第三方库(如 SDL2、GLM)建议用 conanvcpkg 配合 Emscripten toolchain,或直接用 Emscripten 自带的 port(如 -s USE_SDL=2

导出函数供 JavaScript 调用

默认 C++ 函数不会暴露给 JS。要用 EMSCRIPTEN_BINDINGS 或 C 风格导出:

extern "C" {
    int add(int a, int b) {
        return a + b;
    }
}

编译时加:
em++ math.cpp -o math.js -s EXPORTED_FUNCTIONS='["_add"]' -s EXPORTED_RUNTIME_METHODS='["ccall","cwrap"]'

  • EXPORTED_FUNCTIONS 列出要导出的函数名(带下划线前缀)
  • EXPORTED_RUNTIME_METHODS 启用 JS 辅助方法,如 ccall 可直接调用
  • 在 HTML 中:
    <script src="math.js"></script><br>
      <script>console.log(Module.ccall('add', 'number', ['number','number'], [2,3]));</script>

基本上就这些。Emscripten 编译流程和原生 g++ 接近,关键在环境、入口控制和 JS 交互设计。不复杂但容易忽略服务托管和符号导出细节。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

890

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

594

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

210

2025.08.29

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

528

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

494

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

638

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5854

2023.08.17

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

6

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.9万人学习

Git 教程
Git 教程

共21课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号