Rust 1.80 提供 Lazy Statics 稳定支持,并支持在模式匹配中使用开区间
Rust 1.80 稳定了LazyCell
和LazyLock
。借助这两个新类型,开发人员可以将数据的初始化延迟到第一次访问时。该版本提供了对开区间的支持以及一些相关的 lint 警告。为了与 C23 兼容,该版本允许使用不带命名参数的可变函数。此外,它还稳定了许多 API。
LazyCell
和LazyLock
可以延迟共享数据的初始化,其中LazyLock
是线程安全的。类似地,OnceCell
和OnceLock
(支持共享数据的一次性初始化,在 Rust 1.70 中已稳定)也可以用于延迟初始化,只是不那么符合人体工程学。
以下代码使用LazyLock
定义一个延迟初始化的全局变量:
use std::sync::LazyLock;
static G_INT: LazyLock<u8> = LazyLock::new(|| 100);
fn main() {
let x = *G_INT; // 初始化发生在这里
// ...
}
在OnceLock
的语法中,你定义一个值而不显式地对其进行初始化。取而代之,你可以在第一次访问它时使用OnceLock::get_or_init()
函数:
use std::sync::OnceLock;
static G_INT: OnceLock<u8> = OnceLock::new();
fn main() {
let x = *G_INT.get_or_init(|| 100);
// ...
}
OnceLock
和OnceCell
的用途与Lazy*
不同,它们是为了确保一个值只初始化一次。使用它们延迟初始化时,你需要在访问它们的每个地方都使用相同的初始化语句,这很麻烦。在这 4 种类型中,LazyLock
是你在大多数情况下都可以安全地使用的一种类型;如果你想要消除任何与并发相关的开销,则可以使用LazyCell
;OnceLock
和OnceCell
可以方便你灵活地处理初始化逻辑,支持更复杂的用例。
该版本还对该语言做了另外一项有用的补充,就是在模式匹配中支持开区间。在 1.80 版本之前,Rust 只支持闭区间,写为a..=b
或..=b
。现在,你也可以使用a..b
和..b
了。有了这项支持,你可以这样写:
const K: u32 = 10u32.pow(3);
const M: u32 = 10u32.pow(6);
const G: u32 = 10u32.pow(9);
match n {
..K => "",
K..M => "k",
M..G => "M",
G.. => "G",
}
为了降低“差一错误”的可能性,Rust 1.80 引入了两个新的 lint:non_continuous_range_endpoints
和overlapping_range_endpoints
,它们可以在现有代码采用开区间模式时检测错误。
Rust 1.80 还在语言、编译器和标准库中引入了许多其他的变更。一个很小但值得注意的新特性是,支持不带命名参数的可变函数。这相当于删除了一个不允许此类函数的静态检查,使得该语言更接近支持该语法的 C23。
要了解关于 Rust 1.80 中所有新功能和稳定性的详细信息,可以查阅官方的发布说明。
原文链接:
https://www.infoq.com/news/2024/08/rust-1-80-lazy-globals/
声明:本文为 InfoQ 翻译,未经许可禁止转载。
剥离几百万行代码,复制核心算法去美国?TikTok 最新回应来了
利润暴涨 65%后,戴尔一天内裁 12500 人!15 年老员工哭诉:20 万美元期权被扣,管理层贪婪无耻
微信扫码关注该文公众号作者