簡體   English   中英

用下划線實例化Rust泛型是什么意思?

[英]What does it mean to instantiate a Rust generic with an underscore?

在使用serde_json讀取json文檔時,我編寫了以下代碼行來獲取解serde_json::from_str的返回值的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調用結束時的() ,導致以下錯誤:

錯誤:試圖采取方法的值unwrap上型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>
}

這特別方便,因為在許多情況下您可以避免使用“渦輪機操作員”

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

VS

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
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM