全栈程序员的新玩具Rust(六)第一个WASM程序

   2023-02-10 学习力0
核心提示:先上代码https://gitee.com/lightsever/rust_study/tree/master/wasm_hello01webassembly就不用再赘述了,耳朵里面快磨出茧子来了。rustwasm是火狐自家的玩具,让我们来继续做实验,让rust飞起来吧。环境安装安装好rust环境之后仍然需要 一个 wasm 工具包carg

先上代码

https://gitee.com/lightsever/rust_study/tree/master/wasm_hello01


webassembly就不用再赘述了,耳朵里面快磨出茧子来了。

rustwasm是火狐自家的玩具,让我们来继续做实验,让rust飞起来吧。

环境安装

安装好rust环境之后仍然需要 一个 wasm 工具包

cargo install wasm-pack

然后如果想快速创建一个wasm项目模板可以用这个

cargo generate --git https://github.com/rustwasm/wasm-pack-template

WASM项目

生成后的项目代码如下

image

#[wasm_bindgen]就是告诉rust,这个函数要么是导出给js用的,要么希望从js那拿过来用的。

自然 alert是从js那拿过来用

greet是给js调用的


我们搞helloworld,这里就先不改了


这个项目用cargo 编译是生成不了wasm文件的

要在项目目录用

wasm-pack build

image

这样wasm就编译成功了

image

生成的项目是个npm包,自己生成了胶水代码,使用非常方便,但是要用webpack打包。

我自己npm都不熟练,我就不去搞这个了。

主要是不能接受暗藏玄机,我们要来搞一搞事情。

*之前了解不够透彻,这里补充一下

image

wasm-pack 有四个输出目标

我是分不清 browser 和 web 有什么区别,

但是这里有一个no-modules ,就是他,我们就是不想用打包系统

image

所以我写了一个批处理来生成这种js,这样的js我们就不需要改了,使用起来也更方便

后续也不要改动js项目了,使用也更加简单

image

后面的部分都不需要看了

JS项目

我用TS来搞这个项目,他生成的胶水代码是个npm包,所以直接放在网站项目里是不能用的,我们要来改一改。

你或许会有点疑惑都用WASM了?怎么还要写js代码?这是因为WASM不能完全替代js。他需要初始化,丢一些可以import的函数给WASM,要不然WASM啥也不能干。另外需要JS来调用WASM的某个函数,要不然WASM啥也不会干。

也就是说,主要是初始化和入口工作,这个工作可以一次性,然后整个网站的逻辑全部用wasm完成。

image

首先是胶水js,这个文件我们要做三处修改

1.首先

import * as wasm from …

这行删掉,这是告诉js从wasm导入一个模块,它会被打包程序替换,而我们不想用webpack

2.然后是底下有 export的两行

把export 和 const 关键字删除

image

这里是导入js函数给wasm的胶水代码,和导出wasm函数个js的胶水代码。

同理,原来都是 package系统用的东西

好了,改完了

但这样wasm从哪里来?

js在web环境所有的全局变量都是 window 的成员,这样我们随便从哪都能给他塞进去

然后是胶水的定义.d.ts

image

把export 改为 declare,这就成了一个不依赖打包就能使用的定义文件啦。

写我们的app.ts

image

爱用ts,你用js也差不多这样


1.加载 wasm文件 为 arraybuffer


2.实例化wasm对象

这里有个小花招,我们直接把window塞了进去,否则你就需要手工构造一个wasm导入的js胶水函数的字典。因为所有的全局对象都是windows的成员,而rustwasm帮我们生成的胶水代码都是全局定义的,直接丢window进去完事儿。


3.把全局的wasm对象给赋值了,这里直接window[“WASM”]这样塞进去了。


4.调用wasm入口函数


按照我们编写的rust代码,应该alert 出一个  hello peter.

image

诚不欺我。

入口函数和初始化函数一次写完就不用搞了。

以后只消生成wasm就是,当然胶水文件因为我们不是用rustwasm预设的配合webpack的用法,所以我们每次也要改改。但我们的改动其实很机械

1.js文件,有import的 整行删掉

2.js文件,export 开头的,删除 export 和 const关键字

3.d.ts 文件,export开头的,替换成 declare

回头写个脚本,自动办了就是。


今天有了helloworld,写个游戏,就不远了。

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • bloom-server 基于 rust 编写的 rest api cache 中间件
    bloom-server 基于 rust 编写的 rest api cache
    bloom-server 基于 rust 编写的 rest api cache 中间件,他位于lb 与api worker 之间,使用redis 作为缓存内容存储, 我们需要做的就是配置proxy,同时他使用基于share 的概念,进行cache 的分布存储,包含了请求端口(proxy,访问数据) 以及cache 控制端口(
    03-08
  • #新闻拍一拍# Oracle 调研如何避免让 Java 开发者投奔 Rust 和 Kotlin | Linux 中国
    #新闻拍一拍# Oracle 调研如何避免让 Java 开发
     导读:• 英特尔对迟迟不被 Linux 主线接受的 SGX Enclave 进行了第 38 次修订 • ARM 支持开源的 Panfrost Gallium3D 驱动本文字数:977,阅读时长大约:1分钟作者:硬核老王Oracle 调研如何避免让 Java 开发者投奔 Rust 和 KotlinOracle 委托分析公司 Omd
    03-08
  • Linux系统下Rust快速安装:国内镜像加速
    Linux系统下Rust快速安装:国内镜像加速
    官方网址和方法Install Rust - Rust Programming Language然而速度慢得让人难以置信。利用国内镜像进行windows的Linux子系统的Rust安装。rust 使用国内镜像,快速安装方法参考:RUST安装慢怎么办,使用镜像方式安装_网络_为中华之崛起而编程-CSDN博客我的操作
    03-08
  • Rust到底值不值得学--Rust对比、特色和理念
    前言其实我一直弄不明白一点,那就是计算机技术的发展,是让这个世界变得简单了,还是变得更复杂了。当然这只是一个玩笑,可别把这个问题当真。然而对于IT从业者来说,这可不是一个玩笑。几乎每一次的技术发展,都让这个生态变得更为复杂。“英年早秃”已经成
    03-08
  • 超33000行新代码,为Linux内核添加Rust支持的补丁已准备就绪
    超33000行新代码,为Linux内核添加Rust支持的补
    https://mp.weixin.qq.com/s/oKw9aBJSdmRoO6-rbLAkNw7 月 4 日,一套修订后的补丁被提交至 Linux 内核的邮件列表中,该补丁为在 Linux 内核中以 Rust 作为辅助编程语言提供了支持,借助 Rust 可以提高 Linux 内核和内存的安全。整套补丁包含 17 个子项,不光
    03-08
  • 【译】Rust 的 Result 类型入门
    【译】Rust 的 Result 类型入门
    A Primer on Rust’s Result Type 译文原文链接:https://medium.com/@JoeKreydt/a-primer-on-rusts-result-type-66363cf18e6a原文作者:Joe Kreydt译文出处:https://github.com/suhanyujie/article-transfer-rs译者:suhanyujietips:水平有限,翻译不当之
    03-08
  • Rust实战系列-基本语法
    Rust实战系列-基本语法
    主要介绍 Rust 的语法、基本类型和数据结构,通过实现一个简单版 grep 命令行工具,来理解 Rust 独有的特性。本文是《Rust in action》学习总结系列的第二部分,更多内容请看已发布文章:一、Rust实战系列-Rust介绍“主要介绍 Rust 的语法、基本类型和数据结
    03-08
  • 全栈程序员的新玩具Rust(三)板条箱
    上次用到了stdout,这次我们来写一个更复杂一点的游戏rust的标准库叫做std,默认就会引入。这次我们要用到一个随机数函数,而随机数比较尴尬的一点是这玩意不在标准库中,我们要额外依赖一个库。很多编程方案都有自己的模块化库系统,rust也不例外,不过rust
    02-10
  • 【Rust】标准库-Result rust数据库
    环境Rust 1.56.1VSCode 1.61.2概念参考:https://doc.rust-lang.org/stable/rust-by-example/std/result.html示例main.rsmod checked {#[derive(Debug)]pub enum MathError {DivisionByZero,NonPositiveLogarithm,NegativeSquareRoot,}pub type MathResult =
    02-09
  • unity rust_移植到Unity 5 –不为人知的Rust之旅
    unity rust_移植到Unity 5 –不为人知的Rust之
    unity rust Facepunch Studio的创始人Garry Newman和他的团队一直在将Rust移植到Unity 5。 这篇博客文章讲述了尚未结束的《Rust之旅》。 你敢和我们一起旅行吗? (Facepunch Studio’s founder Garry Newman and his team have been porting Rust over to Uni
    02-09
点击排行