let unicode_codepoint = "\u{211D}";
let character_name = "\"DOUBLE-STRUCK CAPITAL R\"";
println!("Unicode символ {} (U+211D) называется {}",
unicode_codepoint, character_name );
let long_string = "Строковый литерал
может занимать несколько строк.
Разрыв строки и отступ ->\
<- также можно экранировать!";
println!("{}", long_string);
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
Иногда приходится экранировать слишком много символов или легче записать строку как она есть. В этот момент в игру вступают сырые строковые литералы.
fn main() {
let raw_str = r"Экранирование здесь не работает: \x3F \u{211D}";
println!("{}", raw_str);
let quotes = r#"И затем я сказал: "Здесь нет экранирования!""#;
println!("{}", quotes);
let longer_delimiter = r###"Строка с "# внутри неё. И даже с "##!"###;
println!("{}", longer_delimiter);
}
Хотите строку, которая не UTF-8? (Помните, str и String должны содержать действительные UTF-8 последовательности). Или возможно вы хотите массив байтов, которые в основном текст? Байтовые строки вас спасут!
use std::str;
fn main() {
let bytestring: &[u8; 21] = b"это строка байтов";
println!("Строка байтов: {:?}", bytestring);
let escaped = b"\x52\x75\x73\x74 как байты";
println!("Экранированные байты: {:?}", escaped);
let raw_bytestring = br"\u{211D} здесь не экранировано";
println!("{:?}", raw_bytestring);
if let Ok(my_str) = str::from_utf8(raw_bytestring) {
println!("И то же самое в виде текста: '{}'", my_str);
}
let _quotes = br#"Вы также можете использовать удобное для вас форматирование, \
как и с обычными сырыми строками"#;