本篇文章給大家分享的是有關使用C語言怎么實現一個字符函數功能,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
C語言字符函數、內存函數 功能及實現 strlen函數(求字符串長度)注意點模擬實現 strcpy函數(字符串拷貝函數)注意點模擬實現 strcat函數(字符串銜接函數)注意點模擬實現 strcmp函數注意點模擬實現 strstr函數模擬實現 strtok函數使用 strerror函數使用 memcpy函數注意點模擬實現 memmove函數注意點模擬實現 memset函數注意點
統計字符串長度直到\0為止
1、屬于<string.h>庫
2、參數為字符串,返回類型為無符號整型,特別注意下圖
此圖運行結果為>,因為無符號整型加減必為大于0的數,所以此類比較需要避免
3、結束標志為\0
int my_strlen(const char *str){ assert(str); if(*str=='\0'){ return 0; } return 1 + my_strlen(str + 1);//采用遞歸方式 }
將sorc數組內第一個\0前(包括\0)的所有內容拷貝到dest數組。
1、dest數組需要足夠容納source數組
2、source數組一定要有\0作為中止標識
3、dest數組要可以更改
4、\0會被拷入
char *my_strcpy(char *dest,const char *sorc) { assert(dest && sorc); char *ret = dest; while (*dest++ = *sorc++)//當/0被最后一次拷入時,跳出循環 { ; } return ret; }
從dest數組的第一個\0開始將sorc函數內第一個\0前的全部內容拷貝,dest函數的第一個\0會被覆蓋,sorc函數的\0會被拷入。
1、dest數組要足夠容納自身和source數組
2、dest數組必須空間可修改
3、dest、source數組都有\0
4、不可以自己拷貝自己,因為沒有中止條件
char *my_strcat(char *dest, const char *sorc) { char *ret = dest; while (*dest != '\0') { dest++; } while (*dest++ = *sorc++) { ; } return ret; }
比較兩個字符串,逐位比較,若對應位不相同則返回ASCII碼相減的值,若每一位相同(即整個字符串相同)返回0。
1、比較的不是長度,而是對應位置的ASCII碼值
int my_strcmp(const char *str1, const char *str2) { assert(str1 && str2); while (*str1 == *str2) { if (*str1 == '\0' && *str2 == '\0') { return 0; } str1++; str2++; } return *str1 - *str2; }
在母串中尋找子串,若找到則返回母串中子串的首地址,若沒找的則返回空指針
此處使用暴力方法求解,KMP算法可提供更優解
char *my_strstr(char *mum, char *child) { assert(mum && child); const char *pc = mum; while (*pc) { const char *p1 = pc; const char *p2 = child; while (*p1 == *p2 && *p1 && *p2) { p1++; p2++; } if (*p2 == '\0') { return (char *)pc; } pc++; } return NULL; }
1、兩個參數(arr源字符串,sep符號字符串(切割標志))
2、希望得到第二個字符串時候需要傳入空指針
使用
int main() { char arr[]="skyline&csdn.com"; char arr2[30]={0};//因為strtok函數會修改源數組,通常復制后處理 char sep[]="&."; strcpy(arr2,arr); printf("%s\n",strtok(arr2,sep)); printf("%s\n",strtok(NULL,sep)); printf("%s\n",strtok(NULL,sep)); return 0; }
結果:
生成不同的錯誤報警
使用
int main() { prinf("%s\n",strerror(errno));//根據程序出現的問題輸出報錯字符串 }
一個字節一個字節的拷貝,共拷貝count個字節;
1、此函數要對兩個不相關的內存塊(若相同由于算法限制無法)比如
int main() { int num1[6] = {1, 2, 3, 4, 5, 6}; my_memcpy(num1+2, num1, 16);//希望得到121234 //實際得到121212 for (int i = 0; i < 6;i++){ printf("%d", num1[i]); } return 0; }
void my_memcpy(void *dest, void *src, size_t count){ assert(dest && src); while (count--) { *(((char *)dest)) = *(((char *)src)); dest=(char*)dest+1;//最好不要寫成++(char*)dest,gcc編譯器認為(char*)dest不可作為左值 src=(char*)src+1; } }
1、可以接受上文出現的相關內存
void my_memmove(void *dest, void *src, size_t count) { assert(dest && src); if (dest > src)//當目標位置在源位置前,我們要從后向前拷貝 { while (count--) { *(((char *)dest) + count) = *(((char *)src) + count); } } else { while (count--)//)//當目標位置在源位置后,我們要從前向后拷貝 { *(((char *)dest)) = *(((char *)src)); dest=(char*)dest+1; src=(char*)src+1; } } }
將一個個字節設置為某個值,共設置count個字節
1、以字節為單位設置的,如果int num[10]={0},memset(num,1,40),并不能使得數組全為1,因為int數組中一個元素為4個字節實際是,每個元素變成01 01 01 01,所以這是錯誤的
以上就是使用C語言怎么實現一個字符函數功能,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。