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

相关文章

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.

Spring AI集成DeepSeek的详细步骤

《SpringAI集成DeepSeek的详细步骤》DeepSeek作为一款卓越的国产AI模型,越来越多的公司考虑在自己的应用中集成,对于Java应用来说,我们可以借助SpringAI集成DeepSe... 目录DeepSeek 介绍Spring AI 是什么?1、环境准备2、构建项目2.1、pom依赖2.2

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

Goland debug失效详细解决步骤(合集)

《Golanddebug失效详细解决步骤(合集)》今天用Goland开发时,打断点,以debug方式运行,发现程序并没有断住,程序跳过了断点,直接运行结束,网上搜寻了大量文章,最后得以解决,特此在这... 目录Bug:Goland debug失效详细解决步骤【合集】情况一:Go或Goland架构不对情况二:

Python安装时常见报错以及解决方案

《Python安装时常见报错以及解决方案》:本文主要介绍在安装Python、配置环境变量、使用pip以及运行Python脚本时常见的错误及其解决方案,文中介绍的非常详细,需要的朋友可以参考下... 目录一、安装 python 时常见报错及解决方案(一)安装包下载失败(二)权限不足二、配置环境变量时常见报错及

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Deepseek R1模型本地化部署+API接口调用详细教程(释放AI生产力)

《DeepseekR1模型本地化部署+API接口调用详细教程(释放AI生产力)》本文介绍了本地部署DeepSeekR1模型和通过API调用将其集成到VSCode中的过程,作者详细步骤展示了如何下载和... 目录前言一、deepseek R1模型与chatGPT o1系列模型对比二、本地部署步骤1.安装oll

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

Spring Boot整合log4j2日志配置的详细教程

《SpringBoot整合log4j2日志配置的详细教程》:本文主要介绍SpringBoot项目中整合Log4j2日志框架的步骤和配置,包括常用日志框架的比较、配置参数介绍、Log4j2配置详解... 目录前言一、常用日志框架二、配置参数介绍1. 日志级别2. 输出形式3. 日志格式3.1 PatternL