cheerp 简介

简介: 这个文章主要介绍了为什么要用cheerp技术以及和其他对标的技术对比,他的闪光点在哪里。WebAssembly 是一种中间码用于加速浏览器端应用,目前有多种语言可以编译或者交叉到这种格式。当然这个不是本文的内容,详细了解请移步 wasm官网目前支持:cc++是官方推荐的方式,详细使用见文档;其他语言AssemblyScript:语法和 TypeScript 一致,对前端来说学习成本低,为前端编写 WebAssembly 最佳选择;Rust:语法复杂、学习成本高,对前端来说可能会不适应。

这个文章主要介绍了为什么要用cheerp技术以及和其他对标的技术对比,他的闪光点在哪里。

WebAssembly 是一种中间码用于加速浏览器端应用,目前有多种语言可以编译或者交叉到这种格式。当然这个不是本文的内容,详细了解请移步 wasm官网

目前支持:

cc++是官方推荐的方式,详细使用见文档;
其他语言

  1. AssemblyScript:语法和 TypeScript 一致,对前端来说学习成本低,为前端编写 WebAssembly 最佳选择;
  2. Rust:语法复杂、学习成本高,对前端来说可能会不适应。详细使用见文档;
  3. Kotlin:语法和 Java、JS 相似,语言学习成本低,详细使用见文档;
  4. Golang:语法简单学习成本低。但对 WebAssembly 的支持还处于未正式发布阶段,详细使用见文档。

cheerp:

cheerp技术是基于llvm的一个交叉工具技术集合, 目前可以支持到的交叉
c/c++到javascript/asm.js/wasm的功能完备的的可移植方案。

笔者从2014年开始就接触cheerp至今, 一直对这个技术抱有极大的热情。

对比emcc(不懂自行百度)优势和劣势。

优势:

  1. cheerp代码更加简单, 环境配置也简单。
  2. 完备的C++14支持。
  3. 编译后拥有更小的体积(内存模型)
  4. 更容易的混合编程(c++,js,wasm)
  5. 更快的性能
  6. 可以支持降级方案

缺点: 几乎是唯一也是致命的缺点,没有对应的文档。

对比其他交叉到wasm的方案

  1. LLVM AOT支持
  2. 本地数学库支持
  3. 交织流水线优化
  4. 更短的指令集合
  5. 更适合大型项目
  6. 无差别融合asm.js/js库
  7. 超越30%的性能

性能:
c/c++开启优化1200ms >
wasm 1990ms >
c/c++未开启优化 2400ms >
asm.js 2600ms >
node.js 2900ms >
luajit 4500ms>
lua5.2 34000ms

by 钟元 agent.zy@aliyun.com

相关文章
【QT】创建、打开QT项目只显示.pro文件的问题解决
【QT】创建、打开QT项目只显示.pro文件的问题解决
3980 0
|
Web App开发 编解码 Android开发
2023年音视频开发知识技术合集(基础入门到高级进阶)
2023年音视频开发知识技术合集(基础入门到高级进阶)
cesium添加实体不被地形遮挡的参数设置
disableDepthTestDistance:指定从相机到禁用深度测试的距离,关于深度测试我们将在后面的文章中介绍到,由于深度测试的存在,我们的对象很多时候会被地形挡住,如下:
2829 0
cesium添加实体不被地形遮挡的参数设置
|
编解码 图形学 C++
如何在Blender中压缩/减小GLTF模型的大小
Blender是一款功能强大的开源软件,旨在创建3D图形,动画和视觉效果。它支持多种文件格式的导入和导出,包括GLB,GLTF,DAE,OBJ,ABC,USD,BVH,PLY,STL,FBX和X3D。这种适应性使其成为各种3D项目和工作流程的宝贵工具。(https://www.blender.org/download/)。
1126 0
|
9月前
|
机器学习/深度学习 存储 文字识别
阿里国际Ovis2系列模型开源:多模态大语言模型的新突破
阿里国际Ovis2系列模型开源:多模态大语言模型的新突破
396 0
Threejs制作窗户透亮效果
这篇文章讲解了如何在Three.js中制作窗户的透亮效果,包括设置透明材质和光照以实现逼真的窗户渲染效果的技术细节。
289 1
|
CDN
Iconfont——Error: <path> attribute d: Expected number, "MNaNNaNaNaNNaNNaN…".
Iconfont——Error: <path> attribute d: Expected number, "MNaNNaNaNaNNaNNaN…".
170 0
|
12月前
|
存储 缓存 前端开发
CacheStorage详解
CacheStorage 是 Web API 的一部分,用于管理缓存对象的存储。它允许开发者在客户端存储和检索请求-响应对,实现离线访问和性能优化。通过 CacheStorage 接口,可以创建、删除和查询缓存,以及控制资源的缓存策略。
|
JavaScript 前端开发
JavaScript prototype(原型对象)
JavaScript prototype(原型对象)
235 0