C/C++的各種字符串函數(shù)你知道幾個(gè)
一、strrchr
char *strrchr(const char *str, int c)
在參數(shù) str 所指向的字符串中搜索最后一次出現(xiàn)字符 c(一個(gè)無符號(hào)字符)的位置。
參數(shù)
- str -- C 字符串。
- c -- 要搜索的字符。以 int 形式傳遞,最終會(huì)轉(zhuǎn)換回 char 形式。
返回值
該函數(shù)返回 str 中最后一次出現(xiàn)字符 c 的位置。如果未找到該值,則函數(shù)返回一個(gè)空指針。
示例
#include <stdio.h> #include <string.h> int main() { int len; char str[] = "www.baidu.com"; char ch = '.'; char* ret; ret = strrchr(str, ch); printf("%c 后的字符串是 %s\n", ch, ret); return 0; }
輸出
二、atoi
int atoi(const char *str)
把參數(shù) str 所指向的字符串轉(zhuǎn)換為一個(gè)整數(shù)(類型為 int 型)。
參數(shù)
- str -- 要轉(zhuǎn)換為整數(shù)的字符串。
返回值
該函數(shù)返回轉(zhuǎn)換后的長整數(shù),如果沒有執(zhí)行有效的轉(zhuǎn)換,則返回零。
示例
#include <stdio.h> #include <stdlib.h> #include <string.h> int main() { int val; char str[20]="20220228"; val = atoi(str); printf("字符串值 = %s, 整型值 = %d\n", str, val); strcpy(str, "hhhhh"); val = atoi(str); printf("字符串值 = %s, 整型值 = %d\n", str, val); return 0; }
輸出
三、strcat
char *strcat(char *dest, const char *src)
把 src 所指向的字符串追加到 dest 所指向的字符串的結(jié)尾。
參數(shù)
- dest -- 指向目標(biāo)數(shù)組,該數(shù)組包含了一個(gè) C 字符串,且足夠容納追加后的字符串。
- src -- 指向要追加的字符串,該字符串不會(huì)覆蓋目標(biāo)字符串。
返回值
該函數(shù)返回一個(gè)指向最終的目標(biāo)字符串 dest 的指針。
示例
#include <stdio.h> #include <string.h> int main() { char src[50] = "This is source ", dest[50] = "This is destination"; strcat(src, dest); printf("%s", src); return 0; }
輸出
四、strstr
char *strstr(const char *str1, const char *str2)
用于判斷字符串str2是否是str1的子串。如果是,則該函數(shù)返回str2在str1中首次出現(xiàn)的地址;否則,返回NULL。
參數(shù)
- str1-- 要被檢索的 C 字符串。
- str2-- 在 haystack 字符串內(nèi)要搜索的小字符串。
返回值
該函數(shù)返回在 str1中第一次出現(xiàn) str2字符串的位置,如果未找到則返回 null。
示例
#include <stdio.h> #include <string.h> int main() { char str1[20] = "www.baidu.com"; char str2[10] = ".baidu"; char* ret; ret = strstr(str1, str2); printf("%s", ret); return(0); }
輸出
五、strncasecmp
int strncasecmp(const char *s1, const char *s2, size_t n);
Linux下函數(shù),比較參數(shù)s1 和s2 字符串前n個(gè)字符,且忽略字符大小寫
參數(shù)
- s1:字符串1
- s2:字符串2
- len:比較的最大字符數(shù)
返回值
若s1和s2匹配(相等)返回0;若s1大于s2,返回大于0的值;若s1小于s2,返回小于0的值
六、strncpy
char *strncpy(char *dest, const char *src, size_t n)
把 src 所指向的字符串復(fù)制到 dest,最多復(fù)制 n 個(gè)字符。當(dāng) src 的長度小于 n 時(shí),dest 的剩余部分將用空字節(jié)填充。
參數(shù)
- dest -- 指向用于存儲(chǔ)復(fù)制內(nèi)容的目標(biāo)數(shù)組。
- src -- 要復(fù)制的字符串。
- n -- 要從源中復(fù)制的字符數(shù)。
返回值
該函數(shù)返回最終復(fù)制的字符串。
示例
#include <stdio.h> #include <string.h> int main() { char src[40] = "i am src hh."; char dest[12]; memset(dest, '\0', sizeof(dest)); strncpy(dest, src, 10); printf("%s\n", dest); return 0; }
輸出
七、strcspn
size_t strcspn(const char *str1, const char *str2)
檢索字符串 str1 開頭連續(xù)有幾個(gè)字符都不含字符串 str2 中的字符。
參數(shù)
- str1 -- 要被檢索的 C 字符串。
- str2 -- 該字符串包含了要在 str1 中進(jìn)行匹配的字符列表。
返回值
該函數(shù)返回 str1 開頭連續(xù)都不含字符串 str2 中字符的字符數(shù)。
示例:
#include <stdio.h> #include <string.h> int main() { int len; char str1[] = "www.baidu.com"; char str2[] = "bc"; len = strcspn(str1, str2); printf("第一個(gè)匹配的字符在 %d", len); return(0); }
輸出
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
C++實(shí)現(xiàn)飛機(jī)大戰(zhàn)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)飛機(jī)大戰(zhàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11C語言實(shí)現(xiàn)經(jīng)典小游戲井字棋的示例代碼
這個(gè)三子棋游戲是在學(xué)習(xí)C語言的過程中自己編寫的一個(gè)小游戲,現(xiàn)在將自己的思路(主要以流程圖形式和代碼中的注釋表達(dá))和具體代碼以及運(yùn)行結(jié)果分享出來以供大家學(xué)習(xí)參考,希望對(duì)大家有所幫助2022-11-11C/C++中棧(stack)&堆(heap)詳解及其作用介紹
這篇文章主要介紹了C/C++中棧(stack)&堆(heap)詳解及其作用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09C++實(shí)現(xiàn)簡單學(xué)生管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡單學(xué)生管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03C語言中的一維數(shù)組與二維數(shù)組的實(shí)現(xiàn)
數(shù)組可以幫我們巧妙解決生活中的問題,使我們的代碼簡潔,本文主要介紹了C語言中的一維數(shù)組與二維數(shù)組,具有一定的參考價(jià)值,感興趣的可以了解一下2023-12-12C++利用std::forward_list查找插入數(shù)據(jù)方法示例
這篇文章主要給大家介紹了關(guān)于C++利用std::forward_list查找插入數(shù)據(jù)的相關(guān)資料,文中先對(duì)std::forward_list進(jìn)行了詳細(xì)的介紹,而后通過示例代碼給大家介紹了查找的方法,需要的朋友可以參考借鑒,下面話不多說了,來一起看看吧。2017-08-08