gpt4 book ai didi

generics - 用下划线实例化 Rust 泛型是什么意思?

转载 作者:行者123 更新时间:2023-11-29 07:44:24 25 4
gpt4 key购买 nike

在使用serde_json读取json文档时,我写了下面这行代码来获取serde_json::from_str的返回值解包的结果。 :

fn get_json_content(content_s: &str) -> Option<Value> {
let ms: String = serde_json::from_str(content_s).unwrap; // <--

match serde_json::from_str(content_s) {
Ok(some_value) => Some(some_value),
Err(_) => None
}
}

如您所见,我忘记了 ()在通话结束时 unwrap ,这导致了以下错误:

error: attempted to take value of method unwrap on type core::result::Result<_, serde_json::error::Error>

let ms: String = serde_json::from_str(content_s).unwrap;

但是当我进一步研究这个问题时,让我感到奇怪的是:

core::result::Result<_, serde_json::error::Error>

我理解下划线在匹配上下文中的含义,但要实例化一个泛型?那么这是什么意思?我无法在 Rust 书籍、引用资料或网络搜索中找到任何答案。

最佳答案

这是一个占位符。在这种情况下,这意味着编译器没有足够的信息来推断类型。

您可以在代码中使用它让编译器为您推断类型。例如:

pub fn main() {
let letters: Vec<_> = vec!["a", "b", "c"]; // Vec<&str>
}

这特别方便,因为在许多情况下您可以避免使用 "turbofish operator" :

fn main() {
let bar = [1, 2, 3];
let foos = bar.iter()
.map(|x| format!("{}", x))
.collect::<Vec<String>>(); // <-- the turbofish
}

对比

fn main() {
let bar = [1, 2, 3];
let foos: Vec<_> = bar // <-- specify a type and use '_' to make the compiler
// figure the element type out
.iter()
.map(|x| format!("{}", x))
.collect(); // <-- no more turbofish
}

关于generics - 用下划线实例化 Rust 泛型是什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37215739/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com