登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
资讯
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
返回列表
首页
›
业界区
›
安全
›
C/C++与JavaScript的WebAssembly编程(一)
C/C++与JavaScript的WebAssembly编程(一)
[ 复制链接 ]
寇油
2025-6-1 18:53:16
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
1. JavaScript与C/C++混合编程的技术
JavaScript与C++混合编程可以实现两种语言的优势结合,C++的程序性能很高且支持强大的系统调用能力,JavaScript则生态丰富且开发效率高。
JavaScript与C++混合编程常见的技术手段主要有以下几种:
Node.js的C++扩展
: 常用于Node.js实现的后端服务代码。在WebAssembly出现之前,Node.js的服务器代码通常以这种方式调用C/C++的模块。
JsAPI和Native API
: 常应用于包含WebView的客户端。将Native端的代码封装成Web接口(JsAPI)供前端调用,将Web端的代码封装成Native接口供Native调用。像Electron、CEF技术栈的客户端均采用了此种方式。
WebAssembly
: 主要用于浏览器上运行的前端页面,Node.js从8.0开始也支持WebAssembly,因此也可用于服务端开发。
本章所讲的内容是基于WebAssembly的混合编程技术。
2. 什么是WebAssembly?
WebAssembly
是一种新的编码方式,是一种为web设计的高效、低级字节码格式。我们可以将C/C++、Rust等低级语言编写的代码编译成WebAssembly字节码,现代的Web浏览器可以加载WebAssembly,并与JavaScript协同运行。从而使得
WebAssembly成为JavaScript与C/C++混合编程并在Web上运行的最有效机制
。C/C++编译成的WebAssembly能够以接近原生语言的效率在浏览器上运行。
2.1. 支持WebAssembly的浏览器
支持WebAssembly的常用浏览器及版本:
Chrome 57及以上版本。
Firefox 52及以上版本。
Edge 16(基于Chromium的版本)及以上。
Safari 11及以上版本。
Opera 44及以上版本。
参考信息: https://caniuse.com/wasm
此外,Node.js从8.0版本也开始支持WebAssembly,WebAssembly目前已经成了W3C的Web标准之一。
2.2. WebAssembly的编译器
除了C/C++外,WebAssembly还支持多种其他计算机语言编译成.wasm,常见的语言和编译器如下:
C/C++
: emscripten编译工具链可以将 C/C++ 编译成 WebAssembly。
Rust
: wasm-pack:工具可以将 Rust 编译成 WebAssembly。
Go
: Go语言的官方工具就链支持将 Go 编译成 WebAssembly。
3. 开发环境搭建
emscripten官方文档: https://emscripten.org/docs/getting_started/downloads.html
依赖的环境准备
git
Python3.6或更新版本(Windows)
安装步骤
# 1. 从Github上克隆emsdk仓库
# emsdk即Emscripten SDK,是将C/C++编译成WebAssembly的工具
git clone https://github.com/emscripten-core/emsdk.git
# 2. 进入emsdk目录
cd emsdk
# 3. 下载和安装最新的SDK tools(包括node.js、emscripten等)
# Linux/macOS:
./emsdk install latest
# Windows:
./emsdk.bat install latest
# (安装大概需要十几分钟的时间,可以去喝杯茶休息一下了)
# 会将相关的工具安装在以下三个目录
# emsdk/node
# emsdk/upstream
# emsdk/python (Windows才有,会安装nuget)
# 4. 为当前用户设置latest版本为当前激活的工具
# Linux/macOS:
./emsdk activate latest
# Windows:
./emsdk.bat activate latest
# 5. 为当前命令终端设置环境变量
# Linux/macOS:
source ./emsdk_env.sh
# Windows:
./emsdk_env.bat
# 6. 验证是否安装成功
emcc -v
# (如果有显示正常的版本信息,则说明安装成功)
复制代码
以上示例基于3.1.72版本的emscripten。
4. Hello World程序
我们从一个Hello World程序开始,了解WebAssembly程序的开发、编译、运行的大致流程。
<ol>新建一个测试目录hello_world和源码文件hello.cpp。
[code]// hello_world/hello.cpp#include int main(){ std::cout
JavaScript
WebAssembly
编程
相关帖子
JavaScript 基础笔记碎片-数据类型、变量与字符串操作
超参数调整,批量标准化和编程框架(四)编程框架
Linux命令行与Shell脚本编程大全笔记
超参数调整,批量标准化和编程框架 课后习题和代码实践
AI 编程协作,我的一点邪修方法,希望可以帮助到你
AiStudio才是Gemini模型的编程真身!
【AI编程】5分钟用AI复刻有BOSS战的《坦克大战》
不止编程!Claude Code 跨界应用指南:5 大垂直领域关键词用法 + PoloAPI 省钱技巧
告别“草率编程”:Vibe Engineering 如何重新定义资深工程师的护城河
函数式编程与传统编程的对比——基于java
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
代码
JavaScript 基础笔记碎片-数据类型、变量与字符串操作
1
681
撒阗奕
2025-11-19
业界
超参数调整,批量标准化和编程框架(四)编程框架
2
463
窖咎
2025-11-20
安全
Linux命令行与Shell脚本编程大全笔记
0
662
吉娅寿
2025-11-26
业界
超参数调整,批量标准化和编程框架 课后习题和代码实践
1
45
迭婵椟
2025-11-29
业界
AI 编程协作,我的一点邪修方法,希望可以帮助到你
0
213
嗅叽
2025-12-03
科技
AiStudio才是Gemini模型的编程真身!
2
218
莠畅缕
2025-12-06
业界
【AI编程】5分钟用AI复刻有BOSS战的《坦克大战》
0
900
勉欤铅
2025-12-14
安全
不止编程!Claude Code 跨界应用指南:5 大垂直领域关键词用法 + PoloAPI 省钱技巧
0
505
尝琨
2025-12-17
业界
告别“草率编程”:Vibe Engineering 如何重新定义资深工程师的护城河
1
723
訾懵
2025-12-17
业界
函数式编程与传统编程的对比——基于java
0
965
志灿隐
2025-12-17
回复
(4)
步雪卉
2025-12-6 19:52:29
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
不错,里面软件多更新就更好了
仄谦
5 天前
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
分享、互助 让互联网精神温暖你我
费卿月
4 天前
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
感谢分享
董绣梓
3 天前
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
感谢分享,下载保存了,貌似很强大
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
签约作者
程序园优秀签约作者
发帖
寇油
3 天前
关注
0
粉丝关注
26
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
3934307807
991124
anyue1937
9994893
kk14977
6845358
4
xiangqian
638210
5
韶又彤
9997
6
宋子
9982
7
闰咄阅
9993
8
刎唇
9993
9
俞瑛瑶
9998
10
蓬森莉
9951
查看更多
今日好文热榜
99
从 Tool Calling 到 A2A,再到 MCP. 大模型
373
BUUCTF 0ctf_2018_heapstorm2 PWN house of
289
仅通过一句提示词,就可以让大模型变得更有
978
生成式引擎优化(GEO优化)全维度技术指南
543
GEO优化实战指南2025:六大服务商核心能力
758
原始类型与泛型对比笔记
683
印度股票数据 API 对接实战指南(含实时行
657
Apipost分支功能:为API开发打造专属的成本
328
OpenCVSharp:学习人脸检测例子
550
JSAPIThree 加载单体三维模型学习笔记:Sim
124
读捍卫隐私09匿名指南
72
工作中常用函数详解与示例-PostgreSQL(其他
589
很顶!零成本克隆你的声音,这款B站开源神
680
go语言/golang 自动升级配置
965
函数式编程与传统编程的对比——基于java
233
pgAdmin 后台命令执行漏洞复现及分析(CVE-
858
度假村亲子水上乐园设备哪家质量好?
286
上下文协议(MCP)Java SDK 指南
699
Mac办公效率翻倍?Charmstone教你玩转多任
774
深耕上海14年,专业防水补漏:如何为厂房、