C語言字符串函數
以下是c語言中常見的字符串操作函數的源代碼,雖然有些與庫函數的函數寫法相同,但是這些都是筆者自己想出來然後實現的,希望對其他博友有所幫助。
注:函數名帶了n的代表是按照一定的字節數操作
//求字符串長度
int strlen(const char* str) {
const char* start = str;
while (*str++);
return (str - start - 1);
}
//複製字符串
char* my_strcpy(char* dest,const char* src) {
char* ret = dest;
while (*dest++ = *src++);
return ret;
}
char* my_strncpy(char* dest, char* src,int sz) {
char* ret = dest;
while (*dest++ = *src++, sz--);
return ret;
}
//拼接字符串
char* my_strcat(char* dest, char* src) {
char* ret = dest;
while (*dest++);
int i = 0;
while ((*(dest - 1 + i)) = *(src + i++));
return ret;
}
char* my_strncat(char* dest, char* src, int sz) {
char* ret = dest;
while (*dest++);
int i = 0;
while ((*(dest - 1 + i)) = *(src + i++), sz--);
return ret;
}
//比較兩個字符串是否相同
char* my_strcmp(char* dest, char* src) {
while (*dest++ == *src++)
if (!*dest && !*src) return 0;
if (*(dest - 1) > *(src - 1)) return 1;
else return -1;
}
char* my_strncmp(char* dest, char* src, int sz) {
while (*dest++ == *src++)
if (!*dest && !*src) return 0;
if (*(dest - 1) > *(src - 1)) return 1;
else return -1;
}
//在字符串中尋找子字符串
char* my_strstr(char* str1, char* str2) {
while (*str1++) {
int i = 0;
while (*(str1 - 1 + i) == *(str2 + i++))
if ((str2 + i) == 0) return str1-1;
}
return 0;
}
如若有問題可以留言相互討論,相互促進~(≧▽≦)/~~!!