大家好,我是渔夫。
今天分享主题,如何加快 Rust 项目编译时间的技巧,如果你还是个初学者,可能还体会不到它多慢。
首先,建议确保你使用最新的 Rust 版本,因为,Rust 团队正在努力改变这个事实,其实到今年为止,编译器速度全面提高了 30-40% 了,一些项目的提高幅度高达 45% 以上。所以保持新版的好处。
更新命令在这里:rustup update。
在许多数情况下,如果只想检查代码是否存在错误,是不必进行完整的编译过程的。所以,尽量避免进行编译,而是使用快速的代码检查、类型检查和借用检查。
如何搞呢,建议使用 cargo check 而不是 cargo build。因为 cargo check 会快速检查代码,而不会生成可执行的二进制文件。
这个好处很多了,当使用 cargo watch -c 它是可以自动在代码发生变化时进行代码检查,这样你就可以更快地发现错误并进行及时修复。优点:即时反馈、提高效率、减少错误和方便性。
你可以在 Nightly 版本中,启用新的并行编译器前端。使用 -Z threads=8 选项运行 Nightly 编译器:
RUSTFLAGS="-Z threads=8" cargo +nightly build
也可以通过添加 -Z threads=8到~/.cargo/config.toml文件中将其设为默认值:
[build]rustflags = ["-Z", "threads=8"]
还可以在 shell 的配置文件中设置别名(例如/.bashrc或/.zshrc):
alias cargo="RUSTFLAGS='-Z threads=8' cargo +nightly"
启用 -Z threads=8 多线程编译选项后,基准测试显示编译时间可能减少多达 50%。尽管实际性能提升会根据代码而变化,但还是可以试试。
以下是并行编译器前端运行中的可视化,官网也可以说明:
删除未使用的依赖,减少构建时间和资源消耗及减小项目体积。
cargo install cargo-machete && cargo machete
运行 cargo build --timings 命令,这会提供关于每个 crate 编译所花费的时间信息。
如果,你想更加深入地了解 Rust 编译过程使用 cargo rustc -- -Zself-profile 进行编译时间分析。生成的跟踪文件可以使用火焰图或 Chromium 分析器进行可视化。
cargo install cargo-nextestcargo nextest run
Cargo 提供了一个小型测试运行器,这非常方便。但特别是在需要构建多个测试二进制文件时,由于其并行执行模型,使用cargo nextest 可以比cargo test 提高高达 60% 的速度。以下是一些快速基准测试:
本文链接:http://www.28at.com/showinfo-26-81248-0.html加速 Rust 编译时间,掌握这个技巧,速度全面提升 30 ~ 40 %
声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com
上一篇: e.target 和 e.currentTarget 的区别?你到底知不知道?
下一篇: 用代码实现流水线部署,像诗一般优雅