C/C++的各種字符串函數(shù)你知道幾個(gè)
一、strrchr
char *strrchr(const char *str, int c)
在參數(shù) str 所指向的字符串中搜索最后一次出現(xiàn)字符 c(一個(gè)無(wú)符號(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)換后的長(zhǎng)整數(shù),如果沒(méi)有執(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 的長(zhǎng)度小于 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 開(kāi)頭連續(xù)有幾個(gè)字符都不含字符串 str2 中的字符。
參數(shù)
- str1 -- 要被檢索的 C 字符串。
- str2 -- 該字符串包含了要在 str1 中進(jìn)行匹配的字符列表。
返回值
該函數(shù)返回 str1 開(kāi)頭連續(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é)
本篇文章就到這里了,希望能夠給你帶來(lái)幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
C++基于隨機(jī)數(shù)實(shí)現(xiàn)福彩雙色球的方法示例
這篇文章主要介紹了C++基于隨機(jī)數(shù)實(shí)現(xiàn)福彩雙色球的方法,結(jié)合完整實(shí)例形式分析了C++隨機(jī)數(shù)算法的實(shí)現(xiàn)與使用技巧,需要的朋友可以參考下2017-06-06c語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易版三子棋(附完整代碼)
大家好,本篇文章主要講的是c語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易版三子棋(附完整代碼),感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01C語(yǔ)言?超詳細(xì)總結(jié)講解二叉樹(shù)的概念與使用
二叉樹(shù)可以簡(jiǎn)單理解為對(duì)于一個(gè)節(jié)點(diǎn)來(lái)說(shuō),最多擁有一個(gè)上級(jí)節(jié)點(diǎn),同時(shí)最多具備左右兩個(gè)下級(jí)節(jié)點(diǎn)的數(shù)據(jù)結(jié)構(gòu)。本文將詳細(xì)介紹一下C++中二叉樹(shù)的概念和結(jié)構(gòu),需要的可以參考一下2022-04-04利用Matlab實(shí)現(xiàn)時(shí)域分析功能的示例詳解
利用MATLAB可以方便地進(jìn)行控制系統(tǒng)的時(shí)域分析。這篇文章主要通過(guò)簡(jiǎn)單的示例為大家介紹了Matlab進(jìn)行時(shí)域分析的具體操作,需要的可以參考一下2023-02-02C++ Template 基礎(chǔ)篇(一):函數(shù)模板詳解
這篇文章主要介紹了C++ Template函數(shù)模板,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04C語(yǔ)言實(shí)現(xiàn)二叉樹(shù)遍歷的迭代算法
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)二叉樹(shù)遍歷的迭代算法,包括二叉樹(shù)的中序遍歷、先序遍歷及后序遍歷等,是非常經(jīng)典的算法,需要的朋友可以參考下2014-09-09Matlab實(shí)現(xiàn)好看的配對(duì)箱線圖的繪制
配對(duì)箱線圖,常見(jiàn)于配對(duì)樣本的數(shù)據(jù)分析中,它除了能夠表現(xiàn)兩組的整體差異,還能夠清晰地呈現(xiàn)單個(gè)樣本的前后改變。本文將用Matlab實(shí)現(xiàn)配對(duì)箱線圖的繪制,需要的可以參考一下2022-08-08C++中的類成員函數(shù)當(dāng)線程函數(shù)
這篇文章主要介紹了C++中的類成員函數(shù)當(dāng)線程函數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11