Win10/11系统Rust安装 + WebAssembly入门实战(从0到1超详细)

2024-03-08 15:40

本文主要是介绍Win10/11系统Rust安装 + WebAssembly入门实战(从0到1超详细),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 1 Windows下安装Rust
    • 2 Rust Hello World
      • 采坑备注
    • 3 rustup 更新
    • 4 crates搬家:指定CARGO_HOME
    • 5 VSCode Rust插件(强烈推荐)
    • 6 Rust + WebAssembly上手初探
    • 6 不用Webpack打包前端代码,直接浏览器访问
      • 踩坑备注:

1 Windows下安装Rust

1、Windows系统,先到官网下载安装Rustup(内含Cargo,即Rust 的构建工具和包管理器)

https://www.rust-lang.org/zh-CN/learn/get-started

​ 注意:在Windows上,安装Rust前,会提示先安装依赖的Microsoft C++构建工具,下载地址

https://visualstudio.microsoft.com/zh-hans/visual-cpp-build-tools/

下载下来之后,居然是一个Visual Studio Installer的集成安装工具,为了节省空间,只需要勾选C++生成工具,另外语言包至少勾选"英语"。安装后总共占用5个多G的存储空间。注意选择安装位置,否则默认安装到C盘**。

MS C++安装

安装完成之后需要重启电脑。

如果不安装的话,直接cargo run会有如下提示:

PS D:\dev\rust\hello-world> cargo runCompiling hello-world v0.1.0 (D:\dev\rust\hello-world)
error: linker `link.exe` not found|= note: program not foundnote: the msvc targets depend on the msvc linker but `link.exe` was not foundnote: please ensure that VS 2013, VS 2015, VS 2017, VS 2019 or VS 2022 was installed with the Visual C++ optionerror: could not compile `hello-world` due to previous error

MSVC++构建工具安装完成之后,直接运行rustup-init.exe,耐心等待Rust安装完成。

Current installation options:default host triple: x86_64-pc-windows-msvcdefault toolchain: stable (default)profile: defaultmodify PATH variable: yes1) Proceed with installation (default)
2) Customize installation
3) Cancel installation
>1 #选1,典型安装即可
#...耐心等待下载安装stable installed - rustc 1.44.1 (c7087fe00 2020-06-17)Rust is installed now. Great!

重新打开一个命令行,输入

> cargo -V
cargo 1.44.1 (88ba85757 2020-06-11)
> rustc -V
rustc 1.44.1 (c7087fe00 2020-06-17)

检查Rust是否安装成功。

2 Rust Hello World

进入某个目录,如D:/dev/rust,执行cargo new hello-world创建一个rust项目。

rust项目名称习惯用短横线进行单词分隔,而rust变量名、函数名习惯用短下划线进行分隔。

cargo new hello-worldCreated binary (application) `hello-world` package
cd ./hello-world
cargo run #编译运行Compiling hello-world v0.1.0 (D:\dev\rust\hello-world)Finished dev [unoptimized + debuginfo] target(s) in 0.89sRunning `target\debug\hello-world.exe`
Hello, world!

采坑备注

​ 可能会遇到的问题:

​ 如果项目中引入了其他crate(Rust的代码发布包),使用默认官方的仓库,因为网络原因很可能会一直Blocking...

​ 解决办法:

​ 1、 删掉{安装目录}/.cargo/.package-cache文件。否则会一直Blocking…
安装目录默认为:C:/Users/用户名

​ 2、 最好是替换掉官方的仓库为国内的镜像地址(俗称换源)。

  • 在C:/Users/admin/.cargo/目录下新建一个config文件,填入如下内容:

    [source.crates-io]
    replace-with = "gitee"[source.gitee]
    registry = "https://gitee.com/Aloxaf/crates.io-index"
    

    这是笔者在gitee找到的一个可以正常使用的镜像,不过可能更新不及时。

    还是建议换成中科大的:

    [source.crates-io]
    replace-with = 'ustc'
    [source.ustc]
    registry = "https://mirrors.ustc.edu.cn/crates.io-index"
    [http]
    check-revoke = false
    

    如果不行,还是可以试试清华大学的镜像

    [source.crates-io]
    replace-with = 'tuna'[source.tuna]
    registry = "https://mirrors.tuna.tsinghua.edu.cn/git/crates.io-index"
    

3 rustup 更新

如果编译中报错:

error[E0658]: `while` is not allowed in a `const fn`

可能是rustup和rust工具链太老了,执行rustup update进行升级。

4 crates搬家:指定CARGO_HOME

rust默认会被安装在C:/users/xxx/.cargo目录下。
可以将安装目录迁移到其他盘符下面,然后添加CARGO_HOME环境变量指向该目录即可。
比如,笔者将CARGO_HOME环境变量设置为:E:\env\rust.cargo

5 VSCode Rust插件(强烈推荐)

可以用VSCode打开,刚刚cargo命令创建的hello-world目录。
强烈推荐如下几个插件:
1,rust-analyzer:它会实时编译和分析你的 Rust 代码,提示代码中的错误,并对类型进行标注。比官方的 rust 插件好用。(两者有冲突,需要禁用另外一个)
2,rust syntax:rust代码语法高亮。
3,crates:检查所依赖的第三方包是否是最新的版本,列出可用的版本。
4,better toml,Toml 配置文件高亮显示,并检查 toml 文件中的错误。
5,rust test lens:可以帮你快速运行某个 Rust 测试。
6,Tabnine:基于 AI 的智能自动补全,高效写代码“神器”。

6 Rust + WebAssembly上手初探

  1. Rust官方对WebAssembly有很好的支持。

cargo-generate 用于快速生成 WASM 项目的脚手架(类似 create-react-app),运行 cargo install cargo-generate开始安装。

cargo install cargo-generate
  1. wasm-pack 用于将 Rust 项目打包成单个 WASM 文件(类似 Webpack),下载地址:

https://rustwasm.github.io/wasm-pack/installer/

下载windows的,直接运行wasm-pack-init.exe安装。

info: successfully installed wasm-pack to `C:\Users\liny\.cargo\bin\wasm-pack.exe`
Press enter to close this window...
  1. 创建一个WASM项目:
cargo generate --git https://github.com/rustwasm/wasm-pack-template

在项目目录下运行wasm-pack build命令,即可编译出 WASM 模块。wasm-pack会在项目的pkg目录下生成 .wasm等文件。

备注:

  1. 可能国内镜像仓库里面缺少一些依赖包的最新版本,导致wasm-pack-template无法build成功,可尝试降低Cargo.toml中依赖项的版本。

  2. build之后会提示[INFO]: Installing wasm-bindgen...这个过程首次可能比较长,笔者等了7分多钟,终于还是完成了。

build成功之后,在pkg目录下生成.wasm文件和相关的js胶水代码。

有点前端基础的同学接下来就知道怎么把.wasm引入前端项目了吧。

6 不用Webpack打包前端代码,直接浏览器访问

上面wasm-pack build生成的代码是Webpack项目的,需要webpack打包成原生js才能跑在浏览器当中。

不过,对于一些简单的前端项目和一些测试代码,笔者喜欢干净、原生的js直接丢浏览器跑。

如此操作一番:

  1. 带参数重新build,生成可以在浏览器跑的js代码
wasm-pack build --target browser 
  1. 自己写一个XHR,从服务器端读取xxx.wasm文件。

    function getAsm(options) {options = options || {};options.type = (options.type || "GET").toUpperCase();options.dataType = options.dataType || "json";var params;var xhr = new XMLHttpRequest();xhr.responseType = 'arraybuffer';xhr.onreadystatechange = function() {if (xhr.readyState == 4) {var status = xhr.status;if((status >= 200 && status < 300) || status == 304) {options.success && options.success(xhr.response);} else {options.error && options.error(status);}}};xhr.open("GET", options.url, true);
    };//把build出来的js胶水代码拷贝到这里var imports = {};//这里放需要导入到rust,让rust调用的函数
    getAsm({url: 'xxx_bg.wasm',success: function(data) {var result = WebAssembly.instantiate(data, imports);result.then(function(data) {//这里就获取到wasm导出的函数//后续就可以通过wasm.xxxFunc()调用Rust代码编译出来的函数了window.wasm = data.instance.exports;})}
    });
    

    踩坑备注:

    观察js胶水代码中对TextDecoder的初始化:

    let cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true });
    

    ignoreBOM参数默认是true,实际上笔者在IPhone和Android机上测试,ignoreBOM为true时,从wasm模块得到的string居然是带BOM的!!(不应该是为true会忽略BOM么?这语义有Bug啊!

    ignoreBOM改为传入false,就OK了。

    这个问题,笔者在另一篇文章有详细说明:WebAssembly+Rust:wasm返回给js的字符串长度看似不对的问题

全文完。

这篇关于Win10/11系统Rust安装 + WebAssembly入门实战(从0到1超详细)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/787577

相关文章

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python包管理工具核心指令uvx举例详细解析

《Python包管理工具核心指令uvx举例详细解析》:本文主要介绍Python包管理工具核心指令uvx的相关资料,uvx是uv工具链中用于临时运行Python命令行工具的高效执行器,依托Rust实... 目录一、uvx 的定位与核心功能二、uvx 的典型应用场景三、uvx 与传统工具对比四、uvx 的技术实

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

Java SWT库详解与安装指南(最新推荐)

《JavaSWT库详解与安装指南(最新推荐)》:本文主要介绍JavaSWT库详解与安装指南,在本章中,我们介绍了如何下载、安装SWTJAR包,并详述了在Eclipse以及命令行环境中配置Java... 目录1. Java SWT类库概述2. SWT与AWT和Swing的区别2.1 历史背景与设计理念2.1.