【Rust】 6. 字符串學習筆記

一、Rust 字符串概述

Rust 字符串是 UTF-8 編碼的文本序列,提供兩種主要類型:

  1. &str - 字符串切片(通常作為引用出現)
  2. String - 動態可變的、擁有所有權的字符串

二、字符串字面量 (&str)

編譯時已知大小,靜態分配在只讀內存中

let greeting: &str = "Hello, world!";
println!("字符串字面量: {}", greeting);

三、String 類型

動態分配在堆上,可增長和修改的所有權字符串

let mut s = String::from("Hello");
s.push_str(", world!");
println!("String 類型: {}", s);

四、創建 String 的多種方式

  1. 創建空字符串
let empty = String::new();
println!("空字符串: '{}'", empty);
  1. 從字面量創建
let from_literal = String::from("初始內容");
println!("從字面量創建: {}", from_literal);
  1. 使用 to_string() 方法
let to_string = "另一個字符串".to_string();
println!("to_string(): {}", to_string);
  1. 使用 format! 宏
let formatted = format!("格式化 {} {}", "字符串", 123);
println!("format! 宏: {}", formatted);

五、修改 String

let mut mutable_string = String::from("Hello");
// 添加單個字符
mutable_string.push('!');
println!("添加字符后: {}", mutable_string);// 添加字符串切片
mutable_string.push_str(" World");
println!("添加字符串后: {}", mutable_string);// 在指定位置插入
mutable_string.insert_str(6, "Rust ");
println!("插入后: {}", mutable_string);

六、字符串訪問和迭代

let text = String::from("Hello");// 獲取第一個字符(Option<char> 類型)
if let Some(first_char) = text.chars().nth(0) {println!("第一個字符: {}", first_char);
}// 迭代所有字符
print!("字符迭代: ");
for c in text.chars() {print!("{} ", c);
}
println!();// 字符串切片(注意:基于字節索引,非ASCII字符需要小心)
let slice = &text[0..1]; // "H"
println!("切片: {}", slice);

七、Unicode 和非 ASCII 字符處理

let unicode_text = "Здравствуйте"; // 俄語"你好"
println!("Unicode 文本: {}", unicode_text);// 字符數統計(不是字節數)
let char_count = unicode_text.chars().count();
let byte_count = unicode_text.len();
println!("字符數: {}, 字節數: {}", char_count, byte_count);// 遍歷 Unicode 字符
print!("Unicode 字符: ");
for c in unicode_text.chars() {print!("{} ", c);
}
println!();

八、字符串轉換和操作

let original = String::from("hello");// 轉換為大寫(返回新字符串)
let upper = original.to_uppercase();
println!("大寫: {}", upper);// 轉換為小寫
let lower = upper.to_lowercase();
println!("小寫: {}", lower);// 字符串替換
let replaced = original.replace("he", "she");
println!("替換后: {}", replaced);// 字符串分割
let sentence = "Rust is awesome!";
let words: Vec<&str> = sentence.split_whitespace().collect();
println!("分割單詞: {:?}", words);

九、&str 和 String 的關系與轉換

// &str → String(需要分配內存)
let slice: &str = "切片";
let owned: String = slice.to_string();
println!("&str 轉 String: {}", owned);// String → &str(零成本轉換)
fn process_text(text: &str) {println!("處理文本: {}", text);
}let string_data = String::from("一些數據");
process_text(&string_data); // 自動解引用轉換

十、原始字符串和轉義

// 普通轉義
let escaped = "包含\"引號\"和\\反斜杠";
println!("轉義字符串: {}", escaped);// 原始字符串(避免轉義)
let raw = r#"原始字符串: "內容" 和 \反斜杠"#;
println!("原始字符串: {}", raw);// 多級原始字符串(處理包含 # 的文本)
let complex_raw = r###"包含 # 號的 "原始" 字符串"###;
println!("復雜原始字符串: {}", complex_raw);

十一、字符串索引的注意事項

// Rust 不允許直接索引字符串(因UTF-8變長編碼)
let sample = "Rust編程";// 錯誤:不能直接索引
// let first_char = sample[0]; // 正確方式:使用字符迭代
if let Some(first) = sample.chars().nth(0) {println!("第一個字符: {}", first);
}// 獲取字符向量(注意性能開銷)
let chars: Vec<char> = sample.chars().collect();
println!("字符向量: {:?}", chars);

十二、字符串連接

// 使用 + 運算符(會獲取所有權)
let s1 = String::from("Hello");
let s2 = String::from(" World");
let combined = s1 + &s2; // s1 被移動,不能再使用
println!("連接后: {}", combined);// 使用 format! 宏(推薦,不會獲取所有權)
let s3 = String::from("Hello");
let s4 = String::from(" World");
let formatted_combine = format!("{}{}", s3, s4);
println!("format! 連接: {}", formatted_combine);
// s3 和 s4 仍然可用

十三、實用字符串方法

let example = String::from("   Rust Programming   ");// 去除首尾空白
let trimmed = example.trim();
println!("去除空白: '{}'", trimmed);// 檢查是否包含子串
let contains = example.contains("Rust");
println!("包含 'Rust': {}", contains);// 查找子串位置
if let Some(pos) = example.find("Programming") {println!("'Programming' 位置: {}", pos);
}// 字符串長度(字節數)
println!("字節長度: {}", example.len());// 判斷是否為空
println!("是否為空: {}", example.is_empty());

十四、總結:

  • &str: 靜態、不可變、零成本抽象的字符串視圖
  • String: 動態、可變、擁有所有權的字符串
  • UTF-8 編碼確保完整的 Unicode 支持
  • 設計注重內存安全和性能
  • 豐富的API支持各種字符串操作

性能提示:頻繁的字符串修改建議使用 String,只讀操作使用 &str

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/94912.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/94912.shtml
英文地址,請注明出處:http://en.pswp.cn/web/94912.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

達夢數據庫-數據文件 (二)

達夢數據庫-數據文件&#xff08;二&#xff09;-自動監控達夢數據庫表空間使用率的 Shell 腳本 自動監控達夢數據庫表空間使用率的 Shell 腳本&#xff0c;支持&#xff1a; ? 實時計算每個表空間的使用率? 設置閾值告警&#xff08;如 >80%&#xff09;? 支持郵件告警&…

如何用 Android 平臺開發第一個 Kotlin 小程序

安裝開發環境下載并安裝最新版 Android Studio&#xff08;官方 IDE&#xff09;&#xff0c;安裝時勾選 Kotlin 插件。確保 JDK 版本為 11 或更高。創建新項目打開 Android Studio 選擇 File > New > New Project&#xff0c;選擇 Empty Activity 模板。在配置界面中&am…

Java常用工具類

異常 (Exception)。程序世界并非總是完美的&#xff0c;異常處理機制就是Java為我們提供的優雅應對錯誤的解決方案。一、為什么需要異常處理&#xff1f;—— 從現實世界說起 想象一下現實生活中的場景&#xff1a; 開車上班&#xff1a;你計劃開車去公司&#xff08;正常流程&…

AWS亞馬遜云賬號注冊指南

AWS是全球領先的云計算平臺&#xff0c;提供廣泛的云服務。賬號注冊是開端&#xff0c;不管是用來學習、搭建個人項目&#xff0c;還是公司項目部署上線需要&#xff0c;都需要進行這一步。提醒&#xff1a;在使用賬戶之前&#xff0c;必須要綁定國際的信用卡&#xff1b;通過我…

云計算學習100天-第31天

Keepalived概念keepalived 是Linux下一個輕量級的高可用解決方案主要是通過虛擬路由冗余協議(VRRP)來實現高可用功能Virtual Router Redundancy Protocol起初就是為了補充LVS功能而設計的&#xff0c;用于監控LVS集群內后端真實服務器狀態后來加入了VRRP的功能&#xff0c;它出…

2025年視覺、先進成像和計算機技術論壇(VAICT 2025)

會議簡介 作為人工智能大數據創新發展論壇的重要分論壇&#xff0c;2025年視覺、先進成像和計算機技術論壇聚焦人工智能感知世界的核心前沿&#xff0c;將于2025年9月18-20日在中國廣州廣東科學館舉行。 視覺與成像技術是智能系統理解環境的關鍵&#xff0c;計算機技術則…

MySQL 與 ClickHouse 深度對比:架構、性能與場景選擇指南

&#x1f31f; 引言&#xff1a;數據時代的引擎之爭 在當今數據驅動的企業環境中&#xff0c;選擇合適的數據庫引擎成為架構設計的關鍵決策。想象這樣一個場景&#xff1a;特斯拉的實時車況分析系統需要在毫秒級延遲下處理數百萬輛汽車的傳感器數據&#xff0c;而某電商平臺的訂…

閉包與內存泄漏:深度解析與應對策略

在 JavaScript 編程中&#xff0c;閉包是一個強大且常用的特性&#xff0c;但如果使用不當&#xff0c;可能會引發內存泄漏問題&#xff0c;影響程序性能甚至導致頁面卡頓。本文將深入剖析閉包導致內存泄漏的原理&#xff0c;結合實例講解&#xff0c;并給出切實可行的避免方法…

open webui源碼分析12-Pipeline

Pipeline是 Open WebUI 的一項創新&#xff0c;它 為任何支持 OpenAI API 規范的 UI 客戶端帶來了模塊化、可定制的工作流 —— 甚至更多功能&#xff01;只需幾行代碼&#xff0c;你就能輕松擴展功能、集成自己的專有邏輯并創建動態工作流。 當你處理計算密集型任務&#xff0…

深入解析 Chromium Mojo IPC:跨進程通信原理與源碼實戰

在現代瀏覽器架構中&#xff0c;多進程設計已經成為標配。Chromium 瀏覽器作為典型的多進程瀏覽器&#xff0c;其瀏覽器進程&#xff08;Browser Process&#xff09;、渲染進程&#xff08;Renderer Process&#xff09;、GPU 進程、Utility 進程等之間的通信&#xff0c;依賴…

【自動化測試】測試分類概述-初步接觸自動化測試

&#x1f525;個人主頁&#xff1a; 中草藥 &#x1f525;專欄&#xff1a;【Java】登神長階 史詩般的Java成神之路 測試分類 了解各種各樣的測試方法分類&#xff0c;不是為了墨守成規按照既定方法區測試&#xff0c;而是已了解思維為核心&#xff0c;并了解一些專業名詞 根…

【Python辦公】快速比較Excel文件中任意兩列數據的一致性

目錄 專欄導讀 項目背景 技術選型 核心技術棧 選型理由 功能特性 ?? 核心功能 ?? 輔助功能 架構設計 整體架構 設計模式 核心代碼解析 1. 類初始化和UI設置 2. 文件選擇和數據加載 3. 數據比較核心算法 4. 結果導出功能 界面設計詳解 布局結構 UI組件選擇 性能優化 1. 內存…

nginx的誕生背景、核心優勢、與 Apache 的對比

下面用“3 個 1 分鐘”幫你快速建立 Nginx 的整體印象&#xff1a; 1 分鐘了解它為何誕生&#xff0c;1 分鐘看懂它的 5 大核心優勢&#xff0c;再花 1 分鐘搞清和 Apache 的關鍵差異。誕生背景&#xff08;2002-2004&#xff09; ? 作者&#xff1a;俄羅斯系統工程師 Igor Sy…

算法題打卡力扣第169題:多數元素(easy)

文章目錄題目描述解法一&#xff1a;暴力解解法二 排序法解法三&#xff1a;Boyer-Moore 投票算法 (最優解)題目描述 解法一&#xff1a;暴力解 定義一個數組C用于存放nums數組中每個數出現的次數&#xff0c;然后再遍歷C&#xff0c;判斷C【i】是否大于? n/2 ?&#xff0c;…

A6.0:PCB的設計流程

第一步&#xff1a;導入網表第二步&#xff1a;結構導入和板框定義1.導入結構文件:加載DXF格式的機械結構圖(含板框、定位孔、限高區)&#xff0c;確保元件布局符合物理約束。2.固定器件預放置:將接插件、按鍵、散熱器等結構敏感元件鎖定到指定位置&#xff0c;避免后期調整沖突…

深度學習在金融訂單簿分析與短期市場預測中的應用

金融訂單簿記錄了市場上買賣雙方的委托訂單信息&#xff0c;包括價格、數量、訂單類型等關鍵要素。其數據具有以下特點&#xff1a; 高頻性&#xff1a;訂單在極短時間內不斷產生與變化&#xff0c;數據更新速度極快&#xff0c;每秒可能產生大量新訂單。序列性&#xff1a;訂單…

C++基礎算法——貪心算法

思想&#xff1a;總是做出在當前看來是最好的選擇 例題一、排隊打水問題 n個人&#xff0c;r個水龍頭&#xff0c;花費時間最少的安排&#xff1f;&#xff08;包含等待時間&#xff09; #include<iostream> #include <bits/stdc.h> using namespace std; int ma…

事務和鎖(進階)

事務和鎖&#xff08;進階&#xff09;一.回顧事務1.什么是事務2 為什么要使用事務3 怎么使用事務二.InnoDB和ACID模型三. 如何實現原子性四.如何實現持久性五.隔離性實現原理1.事務的隔離性2.事務的隔離級別3.鎖1&#xff09;鎖信息2&#xff09; 共享鎖和獨占鎖-Shared and E…

【Mentor Xpedition】預習一下

這個軟件不同于一般的PCB設計軟件&#xff0c;采用獨特的中心庫形式&#xff0c;相比cadence的SCH和PCB更緊湊&#xff0c;或者說本就是一家人&#xff0c;不像orcad和allegro強行捆在一起。 基本symbol給原理用&#xff0c;cell給PCB用。

通過代碼認識 CNN:用 PyTorch 實現卷積神經網絡識別手寫數字

目錄 一、從代碼看 CNN 的核心組件 二、準備工作&#xff1a;庫導入與數據加載 三、核心&#xff1a;用代碼實現 CNN 并理解各層作用 1.網絡層結構 2.重點理解&#xff1a;卷積層參數與輸出尺寸計算 四、訓練 CNN 五、結果分析 卷積神經網絡&#xff08;CNN&#xff09;…