當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Rust AsRef用法及代碼示例


本文簡要介紹rust語言中 Trait core::convert::AsRef 的用法。

用法

pub trait AsRef<T: ?Sized> {
    fn as_ref(&self) -> &T;
}

用於進行廉價的reference-to-reference 轉換。

此 trait 類似於 AsMut 用於在可變引用之間進行轉換。如果您需要進行昂貴的轉換,最好使用類型&T 實現 From 或編寫自定義函數。

AsRef Borrow 具有相同的簽名,但 Borrow 在以下幾個方麵有所不同:

  • AsRef 不同, Borrow 對任何 T 都有一個全麵的 impl,可用於接受引用或值。
  • Borrow 還要求借用值的 Hash Eq Ord 等於擁有值。因此,如果您隻想借用結構體的單個字段,則可以實現 AsRef ,但不能實現 Borrow

注意:這個特質一定不能失敗.如果轉換可能失敗,請使用返回的專用方法Option<T>或一個Result<T, E>.

通用實現

  • 如果內部類型是引用或可變引用,AsRef 自動取消引用(例如:如果 foo 的類型為 &mut Foo&&mut Foo,則 foo.as_ref() 的工作方式相同)

例子

通過使用特征邊界,我們可以接受不同類型的參數,隻要它們可以轉換為指定的類型 T

例如:通過創建一個采用 AsRef<str> 的通用函數,我們表示希望接受所有可以轉換為 &str 作為參數的引用。由於 String &str 都實現了 AsRef<str>,我們可以接受兩者作為輸入參數。

fn is_hello<T: AsRef<str>>(s: T) {
   assert_eq!("hello", s.as_ref());
}

let s = "hello";
is_hello(s);

let s = "hello".to_string();
is_hello(s);

相關用法


注:本文由純淨天空篩選整理自rust-lang.org大神的英文原創作品 Trait core::convert::AsRef。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。