天天看點

c語言中count lt lt ch 1,C語言字元串操作總結大全(超詳細) - 全文

1)字元串操作

strcpy(p, p1) 複制字元串

strncpy(p, p1, n) 複制指定長度字元串

strcat(p, p1) 附加字元串

strncat(p, p1, n) 附加指定長度字元串

strlen(p) 取字元串長度

strcmp(p, p1) 比較字元串

strcasecmp忽略大小寫比較字元串

strncmp(p, p1, n) 比較指定長度字元串

strchr(p, c) 在字元串中查找指定字元

strrchr(p, c) 在字元串中反向查找

strstr(p, p1) 查找字元串

strpbrk(p, p1) 以目标字元串的所有字元作為集合,在目前字元串查找該集合的任一進制素

strspn(p, p1) 以目标字元串的所有字元作為集合,在目前字元串查找不屬于該集合的任一進制素的偏移

strcspn(p, p1) 以目标字元串的所有字元作為集合,在目前字元串查找屬于該集合的任一進制素的偏移

* 具有指定長度的字元串處理函數在已處理的字元串之後填補零結尾符

2)字元串到數值類型的轉換

strtod(p, ppend) 從字元串 p 中轉換 double 類型數值,并将後續的字元串指針存儲到 ppend 指向的 char* 類型存儲。

strtol(p, ppend, base) 從字元串 p 中轉換 long 類型整型數值,base 顯式設定轉換的整型進制,設定為 0 以根據特定格式判斷所用進制,0x, 0X 字首以解釋為十六進制格式整型,0 字首以解釋為八進制格式整型

atoi(p) 字元串轉換到 int 整型

atof(p) 字元串轉換到 double 符點數

atol(p) 字元串轉換到 long 整型

3)字元檢查

isalpha() 檢查是否為字母字元

isupper() 檢查是否為大寫字母字元

islower() 檢查是否為小寫字母字元

isdigit() 檢查是否為數字

isxdigit() 檢查是否為十六進制數字表示的有效字元

isspace() 檢查是否為空格類型字元

iscntrl() 檢查是否為控制字元

ispunct() 檢查是否為标點符号

isalnum() 檢查是否為字母和數字

isprint() 檢查是否是可列印字元

isgraph() 檢查是否是圖形字元,等效于 isalnum() | ispunct()

4)函數原型

原型:strcpy(char desTInaTIon[], const char source[]);

功能:将字元串source拷貝到字元串desTInaTIon中

例程:

#include 《iostream.h》

#include 《string.h》

void main(void)

{

char str1[10] = { “TsinghuaOK”};

char str2[10] = { “Computer”};

cout 《《strcpy(str1,str2)《《endl;

}

運作結果是:Computer

第二個字元串将覆寫掉第一個字元串的所有内容!

注意:在定義數組時,字元數組1的字元串長度必須大于或等于字元串2的字元串長度。不能用指派語句将一個字元串常量或字元數組直接賦給一個字元數組。所有字元串處理函數都包含在頭檔案string.h中。

strncpy(char destination[], const char source[], int numchars);

strncpy:将字元串source中前numchars個字元拷貝到字元串destination中。

strncpy函數應用舉例

原型:strncpy(char destination[], const char source[], int numchars);

功能:将字元串source中前numchars個字元拷貝到字元串destination中

例程:

#include 《iostream.h》

#include 《string.h》

void main(void)

{

char str1[10] = { “Tsinghua ”};

char str2[10] = { “Computer”};

cout 《《strncpy(str1,str2,3)《《endl;

}

運作結果:Comnghua

注意:字元串source中前numchars個字元将覆寫掉字元串destination中前numchars個字元!

原型:strcat(char target[], const char source[]);

功能:将字元串source接到字元串target的後面

例程:

#include 《iostream.h》

#include 《string.h》

void main(void)

{

char str1[] = { “Tsinghua ”};

char str2[] = { “Computer”};

cout 《《strcpy(str1,str2)《《endl;

}

運作結果:Tsinghua Computer

注意:在定義字元數組1的長度時應該考慮字元數組2的長度,因為連接配接後新字元串的長度為兩個字元串長度之和。進行字元串連接配接後,字元串1的結尾符将自動被去掉,在結尾串末尾保留新字元串後面一個結尾符。

原型:strncat(char target[], const char source[], int numchars);

功能:将字元串source的前numchars個字元接到字元串target的後面

例程:

#include 《iostream.h》

#include 《string.h》

void main(void)

{

char str1[] = { “Tsinghua ”};

char str2[] = { “Computer”};

cout 《《strncat(str1,str2,3)《《endl;

}

運作結果:Tsinghua Com

原型:int strcmp(const char firststring[], const char secondstring);

功能:比較兩個字元串firststring和secondstring

例程:

#include 《iostream.h》

#include 《string.h》

void main(void)

{

char buf1[] = “aaa”;

char buf2[] = “bbb”;

char buf3[] = “ccc”;

int ptr;

ptr = strcmp(buf2,buf1);

if(ptr 》 0)

cout 《《“Buffer 2 is greater than buffer 1”《《endl;

else

cout 《《“Buffer 2 is less than buffer 1”《《endl;

ptr = strcmp(buf2,buf3);

if(ptr 》 0)

cout 《《“Buffer 2 is greater than buffer 3”《《endl;

else

cout 《《“Buffer 2 is less than buffer 3”《《endl;

}

運作結果是:Buffer 2 is less than buffer 1

Buffer 2 is greater than buffer 3

原型:strlen( const char string[] );

功能:統計字元串string中字元的個數

例程:

#include 《iostream.h》

#include 《string.h》

void main(void)

{

char str[100];

cout 《《“請輸入一個字元串:”;

cin 》》str;

cout 《《“The length of the string is :”《《strlen(str)《《“個”《《endl;

}

運作結果The length of the string is x (x為你輸入的字元總數字)

注意:strlen函數的功能是計算字元串的實際長度,不包括‘\0’在内。另外,strlen函數也可以直接測試字元串常量的長度,如:strlen(“Welcome”)。

void *memset(void *dest, int c, size_t count);

将dest前面count個字元置為字元c. 傳回dest的值。

void *memmove(void *dest, const void *src, size_t count);

從src複制count位元組的字元到dest. 如果src和dest出現重疊, 函數會自動處理。 傳回dest的值。

void *memcpy(void *dest, const void *src, size_t count);

從src複制count位元組的字元到dest. 與memmove功能一樣, 隻是不能處理src和dest出現重疊。 傳回dest的值。

void *memchr(const void *buf, int c, size_t count);

在buf前面count位元組中查找首次出現字元c的位置。 找到了字元c或者已經搜尋了count個位元組, 查找即停止。 操作成功則傳回buf中首次出現c的位置指針, 否則傳回NULL.

void *_memccpy(void *dest, const void *src, int c, size_t count);

從src複制0個或多個位元組的字元到dest. 當字元c被複制或者count個字元被複制時, 複制停止。

如果字元c被複制, 函數傳回這個字元後面緊挨一個字元位置的指針。 否則傳回NULL.

int memcmp(const void *buf1, const void *buf2, size_t count);

比較buf1和buf2前面count個位元組大小。

傳回值《 0, 表示buf1小于buf2;

傳回值為0, 表示buf1等于buf2;

傳回值》 0, 表示buf1大于buf2.

int memicmp(const void *buf1, const void *buf2, size_t count);

比較buf1和buf2前面count個位元組。 與memcmp不同的是, 它不區分大小寫。

傳回值同上。

char *strrev(char *string);

将字元串string中的字元順序颠倒過來。 NULL結束符位置不變。 傳回調整後的字元串的指針。

char *_strupr(char *string);

将string中所有小寫字母替換成相應的大寫字母, 其它字元保持不變。 傳回調整後的字元串的指針。

char *_strlwr(char *string);

将string中所有大寫字母替換成相應的小寫字母, 其它字元保持不變。 傳回調整後的字元串的指針。

char *strchr(const char *string, int c);

查找字 串string中首次出現的位置, NULL結束符也包含在查找中。 傳回一個指針, 指向字元c在字元串string中首次出現的位置, 如果沒有找到, 則傳回NULL.

char *strrchr(const char *string, int c);

查找字元c在字元串string中最後一次出現的位置, 也就是對string進行反序搜尋, 包含NULL結束符。

傳回一個指針, 指向字元c在字元串string中最後一次出現的位置, 如果沒有找到, 則傳回NULL.

char *strstr(const char *string, const char *strSearch);

在字元串string中查找strSearch子串。 傳回子串strSearch在string中首次出現位置的指針。 如果沒有找到子串strSearch, 則傳回NULL. 如果子串strSearch為空串, 函數傳回string值。

char *strdup(const char *strSource);

函數運作中會自己調用malloc函數為複制strSource字元串配置設定存儲空間, 然後再将strSource複制到配置設定到的空間中。 注意要及時釋放這個配置設定的空間。

傳回一個指針, 指向為複制字元串配置設定的空間; 如果配置設定空間失敗, 則傳回NULL值。

char *strcat(char *strDestination, const char *strSource);

将源串strSource添加到目标串strDestination後面, 并在得到的新串後面加上NULL結束符。 源串strSource的字元會覆寫目标串strDestination後面的結束符NULL. 在字元串的複制或添加過程中沒有溢出檢查, 是以要保證目标串空間足夠大。 不能處理源串與目标串重疊的情況。 函數傳回strDestination值。

char *strncat(char *strDestination, const char *strSource, size_t count);

将源串strSource開始的count個字元添加到目标串strDest後。 源串strSource的字元會覆寫目标串strDestination後面的結束符NULL. 如果count大于源串長度, 則會用源串的長度值替換count值。 得到的新串後面會自動加上NULL結束符。 與strcat函數一樣, 本函數不能處理源串與目标串重疊的情況。 函數傳回strDestination值。

char *strcpy(char *strDestination, const char *strSource);

複制源串strSource到目标串strDestination所指定的位置, 包含NULL結束符。 不能處理源串與目标串重疊的情況。函數傳回strDestination值。

char *strncpy(char *strDestination, const char *strSource, size_t count);

将源串strSource開始的count個字元複制到目标串strDestination所指定的位置。 如果count值小于或等于strSource串的長度, 不會自動添加NULL結束符目标串中, 而count大于strSource串的長度時, 則将strSource用NULL結束符填充補齊count個字元, 複制到目标串中。 不能處理源串與目标串重疊的情況。函數傳回strDestination值。

char *strset(char *string, int c);

将string串的所有字元設定為字元c, 遇到NULL結束符停止。 函數傳回内容調整後的string指針。

char *strnset(char *string, int c, size_t count);

将string串開始count個字元設定為字元c, 如果count值大于string串的長度, 将用string的長度替換count值。 函數傳回内容調整後的string指針。

size_t strspn(const char *string, const char *strCharSet);

查找任何一個不包含在strCharSet串中的字元 (字元串結束符NULL除外) 在string串中首次出現的位置序号。 傳回一個整數值, 指定在string中全部由characters中的字元組成的子串的長度。 如果string以一個不包含在strCharSet中的字元開頭, 函數将傳回0值。

size_t strcspn(const char *string, const char *strCharSet);

查找strCharSet串中任何一個字元在string串中首次出現的位置序号, 包含字元串結束符NULL.

傳回一個整數值, 指定在string中全部由非characters中的字元組成的子串的長度。 如果string以一個包含在strCharSet中的字元開頭, 函數将傳回0值。

char *strspnp(const char *string, const char *strCharSet);

查找任何一個不包含在strCharSet串中的字元 (字元串結束符NULL除外) 在string串中首次出現的位置指針。 傳回一個指針, 指向非strCharSet中的字元在string中首次出現的位置。

char *strpbrk(const char *string, const char *strCharSet);

查找strCharSet串中任何一個字元在string串中首次出現的位置, 不包含字元串結束符NULL.

傳回一個指針, 指向strCharSet中任一字元在string中首次出現的位置。 如果兩個字元串參數不含相同字元, 則傳回NULL值。

int strcmp(const char *string1, const char *string2);

比較字元串string1和string2大小。

傳回值《 0, 表示string1小于string2;

傳回值為0, 表示string1等于string2;

傳回值》 0, 表示string1大于string2.

int stricmp(const char *string1, const char *string2);

比較字元串string1和string2大小,和strcmp不同, 比較的是它們的小寫字母版本。傳回值與strcmp相同。

int strcmpi(const char *string1, const char *string2);

等價于stricmp函數, 隻是提供一個向後相容的版本。

int strncmp(const char *string1, const char *string2, size_t count);

比較字元串string1和string2大小,隻比較前面count個字元。 比較過程中, 任何一個字元串的長度小于count, 則count将被較短的字元串的長度取代。 此時如果兩串前面的字元都相等, 則較短的串要小。

傳回值《 0, 表示string1的子串小于string2的子串;

傳回值為0, 表示string1的子串等于string2的子串;

傳回值》 0, 表示string1的子串大于string2的子串。

int strnicmp(const char *string1, const char *string2, size_t count);

比較字元串string1和string2大小,隻比較前面count個字元。 與strncmp不同的是, 比較的是它們的小寫字母版本。 傳回值與strncmp相同。

char *strtok(char *strToken, const char *strDelimit);

在strToken 串中查找下一個标記, strDelimit字元集則指定了在目前查找調用中可能遇到的分界符。 傳回一個指針, 指向在strToken中找到的下一個标記。 如果找不到标記, 就傳回NULL值。 每次調用都會修改strToken内容, 用NULL字元替換遇到的每個分界符。

c++概念字元串操作

一、char_traits 字元特征類

1)意義:包裝特定串元素的通用行為界面,以便容器實作時依據特征資訊而執行特定行為

2)定義了通用類型名

typedef _Elem char_type;

typedef int int_type;

typedef streampos pos_type;

typedef streamoff off_type;

typedef mbstate_t state_type;

其中 int_type 表示字元元素轉換到特定編碼時的整型表示,pos_type, off_type 分别作為字元串索引和字元串元素偏移的類型,類似容器疊中的指針,疊代類型和指針,疊代器的偏移類型。最後的 state_type 用于存儲流狀态,如出錯,格式控制等等。

3)定義了字元 / 字元串操作的包裝界面,以便通用算法的調用

assign(a, b) 定義将 b 字元指派給 a 字元的過程,實作 a.operator = 的行為

eq(a, b) 定義 a 字元和 b 字元的相等關系,實作 a.operator == 的行為

lt(a, b) 定義 a 小于 b 的關系,實作 a.operator 《 的行為

compare(a_ptr, b_ptr, cnt) 定義兩組字元串的比較,傳回 int 類型,實作類似 memcmp 的行為

length(ptr) 定義取字元串長度,實作類似 strlen 的行為

copy(a_ptr, b_ptr, cnt) 定義兩組字元串的複制,實作類似 memcpy 的行為

move(a_ptr, b_ptr, cnt) 定義兩組字元串的不重疊複制,實作類似 memmove 的行為

assign(ptr, cnt, ch) 定義了填充字元串的過程,實作類似 memset 的行為

to_int_type(ch) 定義了 char_type 到 int_type 整型的轉換過程

to_char_type(n) 定義了 int_type 到 char_type 字元型的轉換過程

eq_int_type(a, b) 定義兩個和目前 char_type 類型對應的 int_type 的相等關系

eof() 定義字元串結尾符,使用整型表示

not_eof(n) 定義非字元串結尾符,若輸入結尾符,則傳回 1,其他輸入傳回原值,即總是不傳回 eof()

4)int_type 類型應是目前字元類型的整型編碼

二、std::string 并不是序列容器,沒有 front() 和 back() 界面用于取出前端和尾端的元素,使用 std::string::operator [] 并傳遞 streampos 類型取得特定元素,如 std::string::size() - 1 作為索引取得最後一個字元

三、basic_string 支援的初始化

1)預設初始化

2)配置設定器

3)複制構造

4)局部複制 [_Roff, _Roff + _Count)

5)局部複制 + 配置設定器

6)C 字元串 [_Ptr, 《null》)

7)C 字元串 + _Count [_Ptr, _Ptr + _Count)

8)C 字元串 + 配置設定器

9)C 字元串 + _Count + 配置設定器 [_Ptr, _Ptr + _Count)

10)_Count * _Ch

11)_Count * _Ch + 配置設定器

12)疊代器 [_ItF, _ItL)

13)疊代器 + 配置設定器

字元到串不能初始化,但支援 operator = 指派和 operator += 累加指派運算。

四、字元串的區間有效性

對串的索引通路在超過字元串的有效區間時,因為串的在實作上對内置的字元緩沖區執行下标通路,是以不會導緻異常,但是将得到不可預知的結果,通常是不可用的。

将其他字元串作為右值輸入時,對該串取出計數大于串大小時按串大小計算。

std::basic_string::size_type 的實際類型為 size_t,在 Visual C++ 7.1 中實作為 unsigned,std::basic_string::npos 被靜态設定為

(basic_string《_Elem, _Traits, _Alloc》::size_type)(-1);

在查找子字元串等操作時,函數傳回 npos 的值表示非法索引。

五、比較字元串

允許的比較對象

1)compare(s2) 其他同類型字元串

2)compare(p) C 風格字元串

3)compare(off, cnt, s2) [off, off + cnt) 同 s2 執行比較

4)compare(off, cnt, s2, off2, cnt2) [off, off + cnt) 同 s2 [off2, cnt2) 執行比較

5)compare(off, cnt, p) [off, off + cnt) 同 [p , 《null》) 執行比較

6)compare(off, cnt, p, cnt2) [off, off + cnt) 同 [p, p + cnt2) 執行比較

傳回 -1, 0, 1 作為小于、等于和大于的比較結果。

六、附加資料

1)使用 operator += 接受其他字元串,C 風格字元串和字元

2)使用 push_back() 在尾部附加字元,并使得通過字元串構造的 back_iterator 可以通路

3)append() 附加

1、append(s) 追加字元串

2、append(s, off, cnt) 追加字元串 s [off, off + cnt)

3、append(p) 追加字元串 [p, 《null》)

4、append(p, cnt) 追加字元串 [p, p + cnt)

5、append(n, c) 填充 n * c

6、append(InF, InL) 追加輸入流 [InF, InL)

4)insert() 插入

1、insert(off, s2) 插入字元串

2、insert(off, s2, off2, cnt2) 插入字元串 s [off2, off2 + cnt2)

3、insert(off, p) 插入字元串 [p, 《null》)

4、insert(off, p, cnt) 插入字元串 [p, p + cnt)

5、insert(off, n, c) 插入 n * c

6、insert(iter) 元素預設值填充

7、insert(iter, c) 插入特定元素

8、insert(iter, n, c) 插入 n*c

9、insert(iter, InF, InL) 插入 [InF, InL)

5)operator +(a, b)

字元串關聯運算符重載中支援 operator + 的形式

1、s + s

2、s + p

3、s + c

4、p + s

5、c + s

七、查找、替換和清除

1)find() 查找

1、find(c, off) 在 s [off, npos) 中查找 c

2、find(p, off, n) 在 s [off, npos) 中查找 [p, p + n)

3、find(p, off) 在 s [off, npos) 中查找 [p, 《null》)

4、find(s2, off) 在 s [off, npos) 中查找 s2

2)find() 的變種

1、rfind() 具有 find() 的輸入形式,反序查找

2、find_first_of() 具有 find() 的輸入形式,傳回第一個比對的索引

3、find_last_of() 具有 find() 的輸入形式,傳回倒數第一個比對的索引

4、find_first_not_of() 具有 find() 的輸入形式,傳回第一個不比對的索引

5、find_last_not_of() 具有 find() 的輸入形式,傳回倒數第一個不比對的索引

3)replace() 替換

1、replace(off, cnt, s2) 将 s [off, off + cnt) 替換成 s2

2、replace(off, cnt, s2, off2, cnt2) 将 s [off, off + cnt) 替換成 s2 [off2, off2 + cnt2)

3、replace(off, cnt, p) 将 s [off, off + cnt) 替換成 [p, 《null》)

4、replace(off, cnt, p, cnt2) 将 s [off, off + cnt) 替換成 [p, p + cnt2)

5、replace(off, cnt, n, c) 将 s [off, off + cnt) 替換成 c * n

使用疊代器的情況:

6、replace(InF, InL, s2) 将 [InF, InL) 替換成 s2

7、replace(InF, InL, p) 将 [InF, InL) 替換成 [p, 《null》)

8、replace(InF, InL, p, cnt) 将 [InF, InL) 替換成 [p, p + cnt)

9、replace(InF, InL, n, c) 将 [InF, InL) 替換成 n * c

10、replace(InF, InL, InF2, InL2) 将 [InF, InL) 替換成 [InF2, InL2)

4)erase() 删除

1、erase(off, cnt) 從字元串 s 中删除 s [off, off + cnt)

2、erase(iter) 從字元串 s 中删除 *iter

3、erase(ItF, ItL) 從字元串 s 中删除 [ItF, ItL)

八、取出字元串

1)取得 C 風格字元串

c_str() 傳回常量類型的 C 風格字元串指針,copy(ptr, cnt, off = 0) 則将指定大小的字元串複制到特定指針。data() 在 Visual C++ 7.1 中僅僅調用了 c_str() 實作。

2)取得子字元串

substr(off, cnt) 取得 s [off, off + cnt) 的副本。

3)複制子字元串

copy(p, off, cnt) 将 s [off, off + cnt) 複制到 p。

九、字元串的緩沖區管理

字元串具有類似 std::vector 的緩沖區管理界面。

size() 取得有效元素長度

max_size() 取得目前記憶體配置設定器能配置設定的有效空間

reserve() 為緩沖區預留白間

capacity() 取得緩沖區的容量

resize() 重設串的長度,可以為其指定初始化值

十、定義輸入疊代器的尾端

向 istream_iterator 傳遞輸入流對象以建立輸入疊代器,輸入疊代器持有輸入流對象的指針,預設建立和讀取流失敗的情況下該指針被設定為 0。并且在實作輸入疊代器間的 operator == 相等運算時,進行持有的流對象指針的相等比較,這樣,預設建立的輸入疊代器将被用于比對輸入流的結束。

* 當輸入流讀取失敗,使用者執行 if, while 條件判斷時,實際上先将判斷值轉換成 void* 類型,或者根據 operator ! 運算符的傳回結果,對輸入流重載 operator void* 和 operator ! 運算符,可以定義輸入流在布爾表達式中的行為,使得當流讀取失敗的情況下,輸入疊代器可以通過布爾表達式來确認,而不是顯式通路 fail() 成員函數。