字符串操作看似簡單,其實非常重要,不注意的話,經常出現代碼運行結果和自己想要的不一致,甚至崩潰。本文總結了一些構建string對象方法、修改string對象的方法、string類型的操作函數、string類型的查找、string對象的比較。
1 構建string對象方法
首先,為了在我們的程序中使用string類型,我們必須包含頭文件 。如下:#include
聲明一個字符串變量很簡單:string Str;
這樣我們就聲明了一個字符串變量,但既然是一個類,就有構造函數和析構函數。上面的聲明沒有傳入參數,所以就直接使用了string的默認的構造函數,這個函數所作的就是把Str初始化為一個空字符串。
String類的構造函數和析構函數如下:
String類函數
說明string s; | 生成一個空字符串s |
string s(s2); | 拷貝構造函數 生成s2的復制品 |
string s("value"); | 用字符串value初始化s |
string s(b,e); | 以區間b,e內的字符作為字符串s的初值 |
string s(cp,n); | 取字符數組,前n個字符作初值 |
string s(s2,pos2); | 將字符串s2"始于位置pos2"部分當作字符串的初值 |
string s(s2,pos1,len); | 將字符串s2內"始于pos1且長度最多len"的部分作為字符串的初值 |
s.~string(); | 銷毀所有字符,釋放內存 |
#include
2 修改string對象的方法
與容器共有的 string 操作: 與容器共有的 string 操作方法 說明s.insert(p,t); | 在迭代器 p 指向的元素之前插入一個值為 t 的新元素,返回指向新插入元素的迭代器 |
s.insert(p,n,t); | 在迭代器 p 指向的元素之前插入 n 個值為 t 的新元素 |
s.insert(p,b,e); | 在迭代器 p 指向的元素之前插入迭代器 b 和 e 標記范圍內所有的元素。返回 void |
s.assign(b,e); | 在迭代器 b 和 e 標記范圍內的元素替換 s。string類型,返回 s;容器類型返回 void |
s.assign(n,t); | 用值為 t 的 n 個副本替換 s。對于 string 類型,該操作返回 s;對于容器類型,則返回 void |
s.erase(p); | 刪除迭代器 p 指向的元素。返回一個迭代器,指向被 刪除元素后面的元素 |
s.erase(b,e); | 刪除迭代器 b 和 e 標記范圍內所有的元素。返回一個迭代器,指向被刪除元素段后面的第一個元素 |
#include
s.insert(pos,n,c); | 在下標 pos 的元素之前插入 n 個字符 c |
s.insert(pos,s2); | 在下標 pos 的元素之前插入 string 對象 s2 |
s.insert(pos,s2,pos2,len); | 在下標為 pos 的元素之前插入 s2 中從下標 pos2 開始的 len 個字符 |
s.insert(pos,cp,len); | 在下標為 pos 打元素之前插入 cp 所指向數組的前len 個字符 |
s.insert(pos,cp); | 在下標為 pos 的元素之前插入 cp 所指向的以空字符結束的字符串副本 |
s.assign(s2); | 用 s2 的副本替換 s |
s.assign(s2,pos2,len); | 用 s2 中從下標 pos2 開始的 len 個字符替換 s |
s.assign(cp,len); | 用 cp 所指向數組的前 len 個字符副本替換 s |
s.assign(cp); | 用 cp 所指向的以空字符結束的字符串替換 s |
s.erase(pos,len); | 刪除從下標 pos 開始的 len 個字符 |
#include
3 適合string類型操作的函數
- substr()主要功能是復制子字符串,要求從指定位置開始,并具有指定的長度。
- append() 方法在被選元素的結尾(仍然在內部)插入指定內容。提示:如需在被選元素的開頭插入內容,請使用prepend()方法。
- replace() 該函數返回一個字符串,其中指定的字符串已經被替換為另一字符串,并且替換的次數也可以指定。
#include
4 string類型的查找
查找函數 說明s.find( args); | 在 s 中查找 args 的第一次出現 |
s.rfind( args); | 在 s 中查找 args 的最后一次出現 |
s.find_first_of( args); | 在 s 中查找 args 的任意字符的第一次出現 |
s.find_last_of( args) ; | 在 s 中查找 args 的任意字符的最后一次出現 |
s.find_first_not_of( args); | 在 s 中查找第一個不屬于 args 的字符 |
s.find_last_not_of( args); | 在 s 中查找最后一個不屬于 args 的字符 |
#include
5 string對象的比較
string對象比較函數compare用法 說明str1.compare(str2); | 如果相等則輸出為0,str1>str2輸出大于0,否則,輸出小于0 |
str1.compare(m,n,str2); | str1的子串(從索引m開始,包含n個字符)與str2進行比較 |
str1.compare(m,n,str2,m,n); | str1的子串(從索引m開始,包含n個字符)與str2的子串(從索引m開始,包含n個字符)進行比較 |
#include
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
C語言
+關注
關注
180文章
7604瀏覽量
136813 -
字符串
+關注
關注
1文章
579瀏覽量
20515
原文標題:字符串操作的全面總結(附完整代碼)
文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
base64字符串轉換為二進制文件
Base64是一種編碼方法,用于將二進制數據轉換為ASCII字符串。這種編碼通常用于在不支持二進制數據的系統中傳輸數據,例如電子郵件或網頁。將Base64字符串轉換為二進制文件的過程相對簡單,但需要
MATLAB(5)--字符串處理
。
建立多行字符串,形成字符串矩陣,因為是矩陣,要求各行字符數要相等,也就是列數要相同,當各行字符數不相等時,就要用空格調節各行的長度,使他們的列數彼此相通。
發表于 09-06 10:22
labview字符串數組轉化為數值數組
在LabVIEW中,將字符串數組轉換為數值數組是一項常見的任務,尤其是在處理數據采集、信號處理或用戶輸入時。 1. 理解LabVIEW的數據類型 在開始之前,了解LabVIEW中的數據類型是非
labview字符串如何轉換為16進制字符串
在LabVIEW中,將字符串轉換為16進制字符串是一個常見的需求,尤其是在處理數據通信和硬件接口時。LabVIEW提供了多種方法來實現這一轉換,包括使用內置函數、編寫VI(Virtual
labview中如何實現字符串換行
。 使用 Append String 函數 :在字符串末尾添加換行符。 使用 Format Into String 函數 :格式化字
labview中如何實現字符串選擇輸出
在LabVIEW中實現字符串選擇輸出是一項常見的任務,它涉及到字符串處理、條件判斷和用戶界面設計等多個方面。由于LabVIEW是一種圖形化編程語言,其編程方式與傳統的文本編程語言有所不同,因此實現
labview中常用的字符串函數有哪些?
在LabVIEW中,常用的字符串函數廣泛覆蓋了對字符串的各種操作,包括但不限于格式化、搜索、替換、連接、計算長度等。以下是一些常用的字符串函數及其簡要說明:
labview字符串的四種表示各有什么特點
字符串控件(String Control) 字符串控件是LabVIEW中用于顯示和編輯字符串的圖形界面元素。它允許用戶在前面板(Front Panel)上輸入
銳評Ruby 3.4.0 默認啟用字符串字面量凍結功能
據悉,Ruby自2.3版起引入了“凍結”機制,通過使用frozen_string_literal: true魔法注釋,可令文件內所有字符串字面量默認為凍結狀態,防止開發過程中無意修改字符串,提高代碼穩定性與性能,降低內存占用。
如何提取串口接收字符串數組里的某個字符串?
前幾天搞了好久串口發送接收字符串的程序代碼,終于搞出來了。還沒高興多久,新的問題又來了。我使用STM8S105K4的UART2串口跟藍牙模塊通信的,我發送字符串指令給藍牙后,藍牙返回來了十幾
發表于 04-22 06:05
labview二進制字符串轉數值
字符串是一種常見的數據類型,它表示了以二進制形式存儲的數據。當我們需要將這些二進制字符串轉換為數值時,LabVIEW提供了一些常用的函數和方法,可以幫助我們完成這個任務。 首先,我們需要明確二進制字符串的格式。在LabVIEW中
labview掃描字符串怎么用
LabVIEW 是一種流程化編程語言和開發環境,主要用于控制、測量和監測系統。在 LabVIEW 中,掃描字符串是一項常見的任務,它允許用戶按照一定的模式從輸入字符串中提取所需的信息。下面我將詳細
評論