91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Rust字符串字面值實例分析

發布時間:2022-04-06 13:58:32 來源:億速云 閱讀:215 作者:iii 欄目:開發技術

這篇文章主要講解了“Rust字符串字面值實例分析”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Rust字符串字面值實例分析”吧!

前言

Rust 中有兩種字符串,String 和 &str,其中 String 可動態分配、修改,內部實現可以理解為 Vec<u8>,而 &str 是一個類型為 &[u8] 的切片。這兩種字符串都只能保存合法的 UTF-8 字符。

而對于非肉眼可辨識的 UTF-8 字符,則可以考慮使用如下類型:

  • 文件路徑有專用的 Path 和 PathBuf 類可用。

  • 使用 Vec<u8> 和 &[u8]

  • 使用 OSString 和 &OSStr 和操作系統交互

  • 使用 CString 和 &CStr 和 C 庫交互

上面的第二種方法,就是常用的處理非 UTF-8 字節流的方式,也就是使用 Vec<u8> 和 &[u8] ,其中我們也可以使用字面值來處理這兩種類型的數據,我們稱之為字節字符串字面值(byte string literals),其類型為 &[u8]。

字符串字面值(String literals)

先來看一下字符串字面值。

和其他語言一樣,用雙引號括起來就是一個字符串,不過 Rust 的一個特點是字符串可以跨行,即中間有回車也不會引起編譯或運行錯誤,在輸出的時候也會帶著里面的換行符。

同樣,字符串字面值里面支持轉義,比如想在里面使用雙引號,該轉義也會對換行符進行轉義,比如下面這樣,在換行符前面使用 \ ,則該轉義符、換行符以及下一行開頭的所有空格都將會被忽略:

let a = "foobar";
let b = "foo\
         bar";
assert_eq!(a,b);

字符串字面值除了支持常見的 \ 對字節(字符)進行轉義,還支持對 Unicode 進行轉義:

  • \xHH: + 2位的十六進制7位寬度字節碼,這相當于等值的 ASCII 字符。

  • \u{xxxx}:24位長的16進制,表示等值的 Unicode 字符。

  • \n/\r/\t 表示 U+000A (LF), U+000D (CR) 和 U+0009 (HT)

  • \\ 用來對 \ 本身進行轉義

  • \0 表示 Unicode U+0000 (NUL)

Raw 類型的字符串字面值表示進行轉義,也就是說字面值寫的是什么內容,字符串的值就是什么。這種類型的字面值使用 r 以及若干 # 開頭進行定義,結尾需要相等數量的 #。

如下所示:

"foo"; r"foo";                     // foo
"\"foo\""; r#""foo""#;             // "foo"

"foo #\"# bar";
r##"foo #"# bar"##;                // foo #"# bar

"\x52"; "R"; r"R";                 // R
"\\x52"; r"\x52";                  // \x52

如果字符串中有雙引號怎么辦?因為 raw string 里不能使用轉義,所以 \" 是肯定不行的。Rust 實際支持使用 r# 的方式來指定字符串邊界。這個 # 就是轉義的另一種實現方式,比如字符串里面有 4 個 #,那么該字符串可以用 r#####"abc####def"##### 來包圍起來,也就是比里面的 # 多即可。

Byte string literals

Byte string 字面值使用 b"..." 以及衍生語法定義,其類型為 &[u8],這個和 &str 是完全不一樣的類型,所以有些在 &str 上能用的方法,在 &[u8] 上是用不了的。

比如:

// &[u8; 5]: [119, 111, 114, 108, 100]!
let world = b"world";
println!("Hello, {}!", world);

編譯會報錯,因為 &[u8] 沒有實現 std::fmt::Display:

29 |     println!("Hello, {}!", world);
   |                            ^^^^^ `[u8; 5]` cannot be formatted with the default formatter
   |

   = help: the trait `std::fmt::Display` is not implemented for `[u8; 5]`
   = note: in format strings you may be able to use `{:?}` (or {:#?} for pretty-print) instead
   = note: this error originates in the macro `$crate::format_args_nl` (in Nightly builds, run with -Z macro-backtrace for more info)

Byte string 字面值也支持轉義,但是需要注意它只支持字節轉義,不支持 Unicode 轉義。

// 支持字符轉義,輸出:Hello, Rust!
let escaped = b"\x52\x75\x73\x74 as bytes";

// 不支持 Unicode 轉義,編譯錯誤:
// = help: unicode escape sequences cannot be used as a byte or in a byte string
let escaped = b"\u{211D} is not allowed";
// Raw byte strings work just like raw strings
let raw_bytestring = br"\u{211D} is not escaped here";
println!("{:?}", raw_bytestring);

// Converting a byte array to `str` can fail
if let Ok(my_str) = str::from_utf8(raw_bytestring) {
    println!("And the same as text: '{}'", my_str);
}

字節字符串也支持 raw 定義,和標準字符串類型類似,使用 r 前綴定義 raw byte string 字面值變量。

例如下面的例子中普通的字節字符串需要轉義,raw 字節字符串就不需要使用 \ 進行轉義了。

b"foo"; br"foo";                     // foo
b"\"foo\""; br#""foo""#;             // "foo"

b"foo #\"# bar";
br##"foo #"# bar"##;                 // foo #"# bar

b"\x52"; b"R"; br"R";                // R
b"\\x52"; br"\x52";                  // \x52

感謝各位的閱讀,以上就是“Rust字符串字面值實例分析”的內容了,經過本文的學習后,相信大家對Rust字符串字面值實例分析這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

寿阳县| 全南县| 依兰县| 阳山县| 堆龙德庆县| 邓州市| 阿拉善右旗| 佛坪县| 禹城市| 武汉市| 岳西县| 黄大仙区| 乡宁县| 富平县| 韶关市| 无为县| 华安县| 司法| 桐柏县| 扶风县| 肇源县| 平远县| 沙湾县| 平罗县| 秀山| 静海县| 原平市| 八宿县| 蕲春县| 福鼎市| 宁晋县| 墨江| 怀集县| 文成县| 庄浪县| 朝阳区| 沐川县| 农安县| 百色市| 阿尔山市| 五家渠市|