[英]Rust multiple lifetimes struct can't access beyond the less longer lifetime parameter
struct TwoStrRef<'a, 'b> {
str1: &'a str,
str2: &'b str,
}
fn main() {
let a_ref_struct;
let string_1 = String::from("hello");
let str_ref;
{
let string_2 = String::from("world");
a_ref_struct = TwoStrRef {
str1: &string_1,
str2: &string_2,
};
str_ref = a_ref_struct.str1;
}
// str_ref; // Ok
// a_ref_struct.str1; // Error: `string_2` does not live long enough borrowed value does not live long enough
}
struct TwoStrRef
有兩個生命周期參數a'
和'b
,我將string_1
和string_2
的引用(它們在不同的范圍內, string_1
是更長的)分配給字段str_1
和str_2
,當我嘗試訪問a_ref_struct.str1
超出string_2
的范圍(但與string_1
相同),編譯器會拋出錯誤,這表明string_2
的壽命不夠長。 str1
字段不是包含不在其范圍之外的string_1
的引用嗎? 為什么如果我將 str1 引用分配給str_ref
,我可以在與string_1
相同的范圍內訪問它?
str1
字段不是包含不在其范圍之外的string_1
的引用嗎?
a_ref_struct
在string_2
超出范圍之前被刪除:這是必需的,因為否則對其str2
字段的任何訪問(例如,可能在其刪除處理程序中發生)都將無效。 實際上,如果在刪除string2
之后存在a_ref_struct
,則它的str2
將是對已釋放內存的引用,這是未定義的行為,即使該引用從未被訪問過。
為什么如果我將 str1 引用分配給
str_ref
,我可以在與string_1
相同的范圍內訪問它?
在那里,您只是獲取a_ref_struct.str1
中保存的引用的副本(生命周期為'a
的string_1
)並將該副本存儲到str_ref
中。 然后可以(並且是)刪除a_ref_struct
而不會影響該(復制的)引用。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.