字符串操作看似簡單,其實(shí)非常重要,不注意的話,經(jīng)常出現(xiàn)代碼運(yùn)行結(jié)果和自己想要的不一致,甚至崩潰。本文總結(jié)了一些構(gòu)建string對象方法、修改string對象的方法、string類型的操作函數(shù)、string類型的查找、string對象的比較。
1 構(gòu)建string對象方法
首先,為了在我們的程序中使用string類型,我們必須包含頭文件 。如下:#include
聲明一個(gè)字符串變量很簡單:string Str;
這樣我們就聲明了一個(gè)字符串變量,但既然是一個(gè)類,就有構(gòu)造函數(shù)和析構(gòu)函數(shù)。上面的聲明沒有傳入?yún)?shù),所以就直接使用了string的默認(rèn)的構(gòu)造函數(shù),這個(gè)函數(shù)所作的就是把Str初始化為一個(gè)空字符串。
String類的構(gòu)造函數(shù)和析構(gòu)函數(shù)如下:
String類函數(shù)
說明string s; | 生成一個(gè)空字符串s |
string s(s2); | 拷貝構(gòu)造函數(shù) 生成s2的復(fù)制品 |
string s("value"); | 用字符串value初始化s |
string s(b,e); | 以區(qū)間b,e內(nèi)的字符作為字符串s的初值 |
string s(cp,n); | 取字符數(shù)組,前n個(gè)字符作初值 |
string s(s2,pos2); | 將字符串s2"始于位置pos2"部分當(dāng)作字符串的初值 |
string s(s2,pos1,len); | 將字符串s2內(nèi)"始于pos1且長度最多l(xiāng)en"的部分作為字符串的初值 |
s.~string(); | 銷毀所有字符,釋放內(nèi)存 |
#include
2 修改string對象的方法
與容器共有的 string 操作: 與容器共有的 string 操作方法 說明s.insert(p,t); | 在迭代器 p 指向的元素之前插入一個(gè)值為 t 的新元素,返回指向新插入元素的迭代器 |
s.insert(p,n,t); | 在迭代器 p 指向的元素之前插入 n 個(gè)值為 t 的新元素 |
s.insert(p,b,e); | 在迭代器 p 指向的元素之前插入迭代器 b 和 e 標(biāo)記范圍內(nèi)所有的元素。返回 void |
s.assign(b,e); | 在迭代器 b 和 e 標(biāo)記范圍內(nèi)的元素替換 s。string類型,返回 s;容器類型返回 void |
s.assign(n,t); | 用值為 t 的 n 個(gè)副本替換 s。對于 string 類型,該操作返回 s;對于容器類型,則返回 void |
s.erase(p); | 刪除迭代器 p 指向的元素。返回一個(gè)迭代器,指向被 刪除元素后面的元素 |
s.erase(b,e); | 刪除迭代器 b 和 e 標(biāo)記范圍內(nèi)所有的元素。返回一個(gè)迭代器,指向被刪除元素段后面的第一個(gè)元素 |
#include

s.insert(pos,n,c); | 在下標(biāo) pos 的元素之前插入 n 個(gè)字符 c |
s.insert(pos,s2); | 在下標(biāo) pos 的元素之前插入 string 對象 s2 |
s.insert(pos,s2,pos2,len); | 在下標(biāo)為 pos 的元素之前插入 s2 中從下標(biāo) pos2 開始的 len 個(gè)字符 |
s.insert(pos,cp,len); | 在下標(biāo)為 pos 打元素之前插入 cp 所指向數(shù)組的前l(fā)en 個(gè)字符 |
s.insert(pos,cp); | 在下標(biāo)為 pos 的元素之前插入 cp 所指向的以空字符結(jié)束的字符串副本 |
s.assign(s2); | 用 s2 的副本替換 s |
s.assign(s2,pos2,len); | 用 s2 中從下標(biāo) pos2 開始的 len 個(gè)字符替換 s |
s.assign(cp,len); | 用 cp 所指向數(shù)組的前 len 個(gè)字符副本替換 s |
s.assign(cp); | 用 cp 所指向的以空字符結(jié)束的字符串替換 s |
s.erase(pos,len); | 刪除從下標(biāo) pos 開始的 len 個(gè)字符 |
#include

3 適合string類型操作的函數(shù)
- substr()主要功能是復(fù)制子字符串,要求從指定位置開始,并具有指定的長度。
- append() 方法在被選元素的結(jié)尾(仍然在內(nèi)部)插入指定內(nèi)容。提示:如需在被選元素的開頭插入內(nèi)容,請使用prepend()方法。
- replace() 該函數(shù)返回一個(gè)字符串,其中指定的字符串已經(jīng)被替換為另一字符串,并且替換的次數(shù)也可以指定。
#include

4 string類型的查找
查找函數(shù) 說明s.find( args); | 在 s 中查找 args 的第一次出現(xiàn) |
s.rfind( args); | 在 s 中查找 args 的最后一次出現(xiàn) |
s.find_first_of( args); | 在 s 中查找 args 的任意字符的第一次出現(xiàn) |
s.find_last_of( args) ; | 在 s 中查找 args 的任意字符的最后一次出現(xiàn) |
s.find_first_not_of( args); | 在 s 中查找第一個(gè)不屬于 args 的字符 |
s.find_last_not_of( args); | 在 s 中查找最后一個(gè)不屬于 args 的字符 |
#include

5 string對象的比較
string對象比較函數(shù)compare用法 說明str1.compare(str2); | 如果相等則輸出為0,str1>str2輸出大于0,否則,輸出小于0 |
str1.compare(m,n,str2); | str1的子串(從索引m開始,包含n個(gè)字符)與str2進(jìn)行比較 |
str1.compare(m,n,str2,m,n); | str1的子串(從索引m開始,包含n個(gè)字符)與str2的子串(從索引m開始,包含n個(gè)字符)進(jìn)行比較 |
#include

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報(bào)投訴
-
C語言
+關(guān)注
關(guān)注
183文章
7634瀏覽量
143905 -
字符串
+關(guān)注
關(guān)注
1文章
594瀏覽量
22894
原文標(biāo)題:字符串操作的全面總結(jié)(附完整代碼)
文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
熱點(diǎn)推薦
labview如何生成一個(gè)帶字符串返回的dll
labview如何生成一個(gè)dll,如下圖,要求一個(gè)輸入,類型是字符串,返回類型也是字符串
發(fā)表于 08-28 23:20
在Python中字符串逆序有幾種方式,代碼是什么
對于一個(gè)給定的字符串,逆序輸出,這個(gè)任務(wù)對于python來說是一種很簡單的操作,畢竟強(qiáng)大的列表和字符串處理的一些列函數(shù)足以應(yīng)付這些問題 了,今天總結(jié)了一下python中對于
harmony-utils之StrUtil,字符串工具類
harmony-utils之StrUtil,字符串工具類 harmony-utils 簡介與說明 [harmony-utils] 一款功能豐富且極易上手的HarmonyOS工具庫,借助眾多實(shí)用工具類
STM32C031C6使用的是UART2通訊,通過printf()函數(shù)發(fā)送字符串時(shí),漢字錯(cuò)碼怎么解決?
使用的是UART2通訊,通過printf()函數(shù)發(fā)送字符串時(shí),漢字錯(cuò)碼(見下圖),應(yīng)該是KEIL哪里沒有設(shè)置好的問題。
啟用了UART2的中斷接收,可以接收到串口調(diào)試助手的數(shù)據(jù),但是緩存區(qū)的指針沒有歸零,下次接收時(shí)緩存區(qū)中的內(nèi)容接續(xù)(如下圖所示),不知道用什么命令來清除緩存區(qū)(即讓指針歸零)。
發(fā)表于 03-07 12:30
請問如何用Verilog實(shí)現(xiàn)將ascaii碼數(shù)值字符串轉(zhuǎn)換成定點(diǎn)數(shù)?
我需要接收一個(gè)ascaii碼字符串,內(nèi)容是12位有效數(shù)字的數(shù)值,帶小數(shù)。我不知道怎么把小數(shù)部分轉(zhuǎn)換成定點(diǎn)數(shù)。
發(fā)表于 01-23 21:57
字符串在數(shù)據(jù)庫中的存儲方式
數(shù)據(jù)庫是現(xiàn)代信息技術(shù)中存儲和管理數(shù)據(jù)的核心組件。字符串作為最常見的數(shù)據(jù)類型之一,在數(shù)據(jù)庫中的存儲方式對其性能和可擴(kuò)展性有著重要影響。 數(shù)據(jù)類型 固定長度字符串 :如CHAR類型,它為每個(gè)字符串分配
字符串在編程中的應(yīng)用實(shí)例
字符串在編程中有著廣泛的應(yīng)用,它們被用于表示文本數(shù)據(jù)、處理用戶輸入、構(gòu)建動態(tài)內(nèi)容等。以下是一些字符串在編程中的應(yīng)用實(shí)例: 1. 用戶輸入與輸出 用戶輸入 :程序通常需要從用戶那里獲取輸入,這些輸入通
字符串與字符數(shù)組的區(qū)別
在編程語言中,字符串和字符數(shù)組是兩種基本的數(shù)據(jù)結(jié)構(gòu),它們都用于存儲和處理文本數(shù)據(jù)。盡管它們在功能上有一定的重疊,但在內(nèi)部表示、操作方式和使用場景上存在顯著差異。 1. 內(nèi)部表示 字符串
字符串反轉(zhuǎn)的實(shí)現(xiàn)方式
在編程中,字符串反轉(zhuǎn)是一個(gè)基礎(chǔ)而重要的操作,它涉及到將一個(gè)字符串中的字符順序顛倒過來。這個(gè)操作在多種編程語言中都有不同的實(shí)現(xiàn)方式,本文將探討
字符串處理方法 字符串轉(zhuǎn)數(shù)字的實(shí)現(xiàn)
在編程中,將字符串轉(zhuǎn)換為數(shù)字是一個(gè)常見的需求。不同的編程語言有不同的方法來實(shí)現(xiàn)這一功能。以下是一些常見編程語言中的字符串轉(zhuǎn)數(shù)字的實(shí)現(xiàn)方法: Python 在Python中,可以使用內(nèi)置的 int
用udl里的字符串信息在局域網(wǎng)內(nèi)其他電腦連接sql數(shù)據(jù)庫為什么為出現(xiàn)連接失敗拒絕訪問?
SQL數(shù)據(jù)庫遠(yuǎn)程連接已經(jīng)開啟。我用udl里的字符串信息,連接輸入的服務(wù)器地址去連接數(shù)據(jù)庫,用戶名和密碼都沒錯(cuò),但是在服務(wù)器的電腦可以連接成功,同局域網(wǎng)內(nèi)其他電腦就會一直報(bào)錯(cuò),拒絕訪問,直接用udl
發(fā)表于 11-16 09:50
base64字符串轉(zhuǎn)換為二進(jìn)制文件
Base64是一種編碼方法,用于將二進(jìn)制數(shù)據(jù)轉(zhuǎn)換為ASCII字符串。這種編碼通常用于在不支持二進(jìn)制數(shù)據(jù)的系統(tǒng)中傳輸數(shù)據(jù),例如電子郵件或網(wǎng)頁。將Base64字符串轉(zhuǎn)換為二進(jìn)制文件的過程相對簡單,但需要
labview中浮點(diǎn)數(shù)與十六進(jìn)制字符串相互轉(zhuǎn)化
與下位機(jī)數(shù)據(jù)交流及通訊時(shí),經(jīng)常有浮點(diǎn)數(shù)與十六進(jìn)制字符串相互轉(zhuǎn)化的需求,經(jīng)過兩天總結(jié),找到了最簡潔的相互轉(zhuǎn)化的方法,萌新歡迎大佬指正,文件也附上。*附件:HEX字符串與浮點(diǎn)數(shù)轉(zhuǎn)換.rar
發(fā)表于 10-21 19:51
《DNK210使用指南 -CanMV版 V1.0》第二十四章 LCD顯示實(shí)驗(yàn)
在LCD上簡單地顯示字符串,draw_string()函數(shù)如下所示:lcd.draw_string(x, y, string, fontc=lcd.RED, bgc=lcd.BLACK
發(fā)表于 10-18 15:02
評論