5 分鐘總結 Rust 生命週期

lifetime 壽命

Rust中的每一個引用都有一個有效的作用域,生命週期就是爲這個作用域服務的,大部分生命週期編譯器可以推斷出來,可以是隱式的。但是如果在某些情況下編譯器就無法正常推斷出來了,需要我們自己手動標註,標註生命週期語法就是'a這樣的語法。

爲什麼需要生命週期?

例如下面例子就是在兩個字符串切片裏面查找最長的那個並且返回!

// 'a 是指3個引用的作用域生命週期要一致
fn find_long_str<'a>(x: &'a str, y: &'a str) -> &'a str {
    if x.len() > y.len() {
        x
    } else {
        y
    }
}

上面我就加註了生命週期標識符,如果不加編譯器會報錯,原因是因爲我們這個函數引用的是外部的變量,不能確定引用的變量是否已經被銷燬了,那這樣就是懸垂引用!

    let str1 = String::from("Hello");
    let str2;
    let result;
    {
        //let str2 = String::from(" World!");
        str2 = String::from(" World!");
        result = find_long_str(str1.as_str()&str2);
    }
    // 這裏借用檢測就提示 引用了已經銷燬的資源了
    println!("{}", result);

大致過程圖

加了生命週期標識符之後,如果我把let str2 = String::from(" World!");取消註釋放在一個內部作用域裏面定義,那麼這時調用find_long_str編譯器就會報錯,因爲我在下面出了作用域還使用了find_long_str返回的結果,而這個結果可能就是str2的內容, 使用這個是違反了所有權規則的,str2離開內部作用域就被銷燬了。

在標註生命週期fn find_long_str<'a>(x: &'a str, y: &'a str) -> &'a str之後編譯器就知道輸入參數和返回參數生命週期是要一致的,並且返回值生命週期肯定是取生命週期最短的那個的。

總結

其他

本文由 Readfog 進行 AMP 轉碼,版權歸原作者所有。
來源https://mp.weixin.qq.com/s/EhFYlbw-s5jO8ZC4qMq6CA