C語言字符串函數(shù)入門
實(shí)現(xiàn)字符串庫函數(shù)功能
有些時(shí)候我們可能會(huì)被限制無法使用庫函數(shù),這個(gè)時(shí)候我們需要編寫自己的庫函數(shù)。但了解了字符串庫函數(shù)的功能之后,想要實(shí)現(xiàn)并不困難,今天我們用數(shù)組和循環(huán)來簡單實(shí)現(xiàn)幾個(gè)字符串庫函數(shù)的功能。
1.strlen函數(shù)
strlen函數(shù)使用來求字符串長度的,遇到\0就會(huì)停止,并返回字符串的長度,接下來根據(jù)這個(gè)特性來編寫一下我們自己的strlen
int my_strlen(char string[]) { int count= 0; while (string[count] != NULL) { count++; } return count; }//也可以將while的判斷條件改為string[count]
有些小伙伴應(yīng)該知道遞歸的實(shí)現(xiàn),但是這里涉及了指針的內(nèi)容,我就不教大家實(shí)現(xiàn)了
2.strcmp函數(shù)
strcmp字符串比較函數(shù),對兩個(gè)字符串進(jìn)行比較,相當(dāng)返回0,前一個(gè)字符串大于后一個(gè)字符串會(huì)返回大于0的數(shù),小于則返回小于0的數(shù),至于具體返回多少,則需要看編譯器。
在實(shí)現(xiàn)strcmp功能之前,我們需要了解它的機(jī)制,strcmp是一個(gè)字符一個(gè)字符的比較ASCII值的
int my_strcmp(char string1[], char string2[]) { int i = 0; //當(dāng)兩個(gè)字符串都沒有達(dá)到末端時(shí),繼續(xù)比較 while ((string1[i] == string2[i]) && string1[i] && string2[i]) i++; return string1[i] - string2[i]; //當(dāng)兩個(gè)字符串指向的字符不一樣或者到達(dá)終點(diǎn)時(shí)返回差值 }
一個(gè)簡單的while循環(huán)就能達(dá)到目的
3.strcpy函數(shù)
字符串拷貝函數(shù),將后一個(gè)字符串拷貝到前一個(gè)字符串中,我們需要保證目的地足夠大
void my_strcpy(char string1[50], char string2[]) { int i = 0; while (string1[i++] = string2[i++]); } //這里利用了賦值表達(dá)式的特性,直接進(jìn)行賦值,當(dāng)string[i]為\0時(shí)賦值完循環(huán)自動(dòng)停止 //當(dāng)然這個(gè)程序并不是完美的,根據(jù)strcpy的返回值我們還可以這樣修改 char* my_strcpy(char string1[50], char string2[]) { int i = 0; while (string1[i++] = string2[i++]); return string1; }//返回目的地的起始地址
4.strcat函數(shù)
strcat字符串追加,在一個(gè)字符串之后追加一個(gè)新的字符串,如果以strcpy的角度理解就是以第一個(gè)字符串的\0位置為起始地址進(jìn)行字符串拷貝,那么接下來就很簡單了
char* my_strcat(char string1[50], char string2[]) { int i = -1; while (string1[++i]);//循環(huán)停止時(shí)i指向\0 int j = 0; while (string1[i++] = string2[j++]); //與strcpy同理 return string1; }
5.strupr函數(shù)
strupr字符串大寫函數(shù),將所有字符串中的小寫字母都變成大寫,我們只需要根據(jù)ASCII值就可以簡單實(shí)現(xiàn)
char*my_strupr(char string[]) { int i = 0; while (string[i]) { //當(dāng)string[i]指向\0時(shí)循環(huán)停止 if (string[i] >= 'a' && string[i] <= 'z') string[i] -= 32; i++; } return string; }
6.strlwr函數(shù)
和strupr對應(yīng),這是字符串小寫函數(shù),把大寫轉(zhuǎn)成小寫,只需要對上面的代碼簡單一改就可以
char*my_strlwr(char string[]) { int i = 0; while (string[i]) { //當(dāng)string[i]指向\0時(shí)循環(huán)停止 if (string[i] >= 'A' && string[i] <= 'Z') string[i] += 32; i++; } return string; }
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
VSCode配置C/C++并添加非工作區(qū)頭文件的方法
這篇文章主要介紹了VSCode配置C/C++并添加非工作區(qū)頭文件的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03C/C++ 中堆和棧及靜態(tài)數(shù)據(jù)區(qū)詳解
這篇文章主要介紹了C/C++ 中堆和棧及靜態(tài)數(shù)據(jù)區(qū)詳解的相關(guān)資料,需要的朋友可以參考下2017-04-04C++中臨時(shí)對象的常見產(chǎn)生情況及其解決的方案
這篇文章主要是探討常見的臨時(shí)對象產(chǎn)生的情況,及其如何避免和解決這種臨時(shí)對象產(chǎn)生的方式。具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09基于Matlab圖像處理的公路裂縫檢測實(shí)現(xiàn)
隨著公路的大量投運(yùn),公路日常養(yǎng)護(hù)和管理已經(jīng)成為制約公路運(yùn)營水平提高的瓶頸,特別是路面狀態(tài)采集、檢測維護(hù)等工作更是對傳統(tǒng)的公路運(yùn)維模式提出了挑戰(zhàn)。這篇文章主要介紹了如何通過Matlab圖像處理實(shí)現(xiàn)公路裂縫檢測,感興趣的可以了解一下2022-02-02