C++ wasm 使用教程

27 篇文章 0 订阅
1 篇文章 0 订阅

环境搭建

  • git clone https://github.com/emscripten-core/emsdk.git
  • git pull
  • ./emsdk install latest
  • ./emsdk activate latest
  • source ./emsdk_env.sh
  • ./emcc -v && ./emcc c11__Thread_local.c -s WASM_WORKERS --threadprofiler --memoryprofiler -v -o test.html && node a.out.js
  • emrun --no_browser --port 8087 .
  • emrun FILENAME.html
  • docker run --rm -v $(pwd):/src -u ( i d − u ) : (id -u): (idu):(id -g)
    emscripten/emsdk emcc helloworld.cpp -o helloworld.js

emcmake

  • call emsdk_env.bat
  • ::TIMEOUT /T 0.5
  • cmd /c buildApp.bat
  • ::TIMEOUT /T 3
  • cd -wasm
  • mkdir wasm
  • cd wasm
  • cmd /c emcmake cmake -DWASM=ON -DPRODUCTMODE=OFF -DSRC_MAP_DEBUG_MODE=%1 -DDEBUG_SRC_SITE=%2 …
  • ::TIMEOUT /T 3
  • ::emmake make clean
  • ::for /l %%a in (1,1,4) do ( emmake make -j32)
  • emmake make -j32
  • pause
  • cmd /c call build_wasm.bat 0 “http://localhost:999/”
  • http-server ./wasm -p 999 --cors
  • emake报错时需将mingw32-make改成make
    MVP CMake

面向WebAssembly编程笔记

创建虚拟文件系统,实现fopen打开本地文

预加载本地文件

./emcc test/hello_world_file.cpp -o hello.html –preload-file test/hello_world_file.txt

Emscripten Test Suite

  def test_cmake_px_icu(self):
    os.mkdir('build')
    self.run_process([EMCMAKE, 'cmake', test_file('cmake/px_icu')], cwd='build')
    self.run_process(['cmake', '--build', 'build'])
    self.assertContained('OK', self.run_js('build/test_prog.js'))

Emscripten 多线程

  • 多线程 -s WASM_WORKERS
  • 单线程 -s SINGLE_FILE
  • lock-free atomic原子不断轮询设置操作,不可中断(其它线程不会读到操作一半的值),解决死锁
  • 示例目录:upstream\emscripten\tests\wasm_worker

NetWork

  • emscripten_async_wget
  • -lwebsocket.js -s WEBSOCKET_URL
  • 捕获异常:-fexceptions -fwasm-exceptions
  • 定时器:emcc -O3 example.cpp -sASYNCIFY
  • 异常位置打印:-fsanitize=undefined ,-fsanitize-minimal-runtime,-fsanitize=address

优化

  • emcc -sENVIRONMENT=web,只生成web代码,不生成nodejs代码,减少大小
  • toolchain profiler:set EMPROFILE=1,emcc test.c -o test.html,emprofile --graph

https://www.cnblogs.com/chenchao521/articles/15493198.html

编译qt源码
进入源码目录,命令行输入,
./configure.bat -no-warnings-are-errors -xplatform wasm-emscripten -platform win32-g++ -nomake examples -prefix %CD%\qtbase
大概10分钟就可以编译完毕

构建需要的模块
E:/Qt/Qt5.10.1/Tools/mingw530_32/bin/make.exe module-qtbase module-qtdeclarative
如果不需要裁剪,可以直接 E:/Qt/Qt5.10.1/Tools/mingw530_32/bin/make.exe

引用

源码调试

DWARF
wamr
vs

示例

demo
wamr
vs

创作不易, 小小的支持一下吧!

微信支付宝

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码力码力我爱你

创作不易,小小的支持一下吧!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值