C语言:字符串函数的使用方法及模拟实现
一、strlen函数
size_t strlen ( const char * str );
strlen的模拟实现:
方法一:计数器方式
int my_strlen(const char * str) { int count = 0; assert(str); while(*str) { count++; str++; } return count; }
方法二:指针-指针
int my_strlen(char *s) { assert(str); char *p = s; while(*p != ‘\0’ ) p++; return p-s; }
二、strcpy函数
char* strcpy(char * destination, const char * source );
1.strcpy使用 :
1.1 strcpy只用于字符串复制,遇到‘\0’时停止,还会复制字符串的结束符'\0'; 所以源字符串必须 以’\0’结束,也会将源字符串的’\0’拷贝到目标空间。
1.2 目标空间必须可变。
1.3 如果参数dest所指的内存空间不够大,可能会造成缓冲溢出的错误情况,在编写程序时需特别 留意,或者用strncpy()来代替。
strcpy的模拟实现:
void my_strcpy(char* p1, char* p2) { while (*p2 != '\0') { *p1 = *p2; p1++; p2++; } *p1 = *p2; } int main() { char arr1[] = "hello"; char arr2[] = "pppp"; my_strcpy(arr1, arr2); printf("%s\n", arr1); return 0; }
三、strcat 函数
1.stract使用 :
1.1 源字符串必须以 '\0' 结束。
1.2 ⽬标字符串中也得有 \0 ,否则没办法知道追加从哪⾥开始。
1.3 ⽬标空间必须有⾜够的⼤,能容纳下源字符串的内容。
2.stract的模拟实现:
char * my_strcat(char* p,const char* t) { assert(p && t); char* ret = p; while (*p != '\0') { p++; } while (*p++ != *t++) { ; } return ret; } int main() { char arr1[20] = "hello"; char arr2[] = "bit"; char* s = my_strcat(arr1, arr2); printf("%s\n", arr1); printf("%s\n",s); return 0; }
四、strcmp函数
1. strcmp的使用:
1.1作用:比较两个字符串的大小。
1.2规则:
第⼀个字符串⼤于第⼆个字符串,则返回⼤于0的数字 。
第⼀个字符串等于第⼆个字符串,则返回0 。
第⼀个字符串⼩于第⼆个字符串,则返回⼩于0的数字。
2.strcmp的模拟实现:
int my_strcmp(const char* str1, const char* str2) { assert(str1 && str2); while (*str1 == *str2) { if (*str1 == '\0') { return 0; str1++; str2++; } } return *str1 - *str2; } int main() { char arr1[] = "abcd"; char arr2[] = "abc"; int ret = my_strcmp(arr1, arr2); printf("%d", ret); return 0; }
五、strncpy函数
char * strncpy ( char * destination, const char * source, size_t num );
1.strncpy的使用:
1.1作用:拷⻉多少字符从源字符串到⽬标空间。
1.2代码实现:
六、strncat函数
char * strncat ( char * destination, const char * source, size_t num );
1.strncat的使用:
1.1使用规则:
strncat()用来连接源字符串的前n个字符到目标字符串后,所以要多传一个参数n。
1.2代码实现:
七、strncmp函数
int strncmp ( const char * str1, const char * str2, size_t num );
1.strncmp的使用:
1.1作用:⽐较str1和str2的前num个字符。
1.2使用规则:如果相等就继续往后⽐较,最多⽐较num个字⺟,如果提前发现不⼀ 样,就提前结束,⼤的字符所在的字符串⼤于另外⼀个。如果num个字符都相等,就是相等返回0。
1.3代码实现:
八、strstr函数
char * strstr ( const char * str1, const char * str2);
1.strstr函数的使用:
1.1作用:用于判断字符串str2是否是str1的子串。
2.strstr的模拟实现:
char* my_strstr(const char* str1, const char* str2) { const char* s1 = NULL; const char* s2 = NULL; const char* cur = str1; if (*str2 == '\0') return (char*)str1; while (*cur) { s1 = cur; s2 = str2; while (*s1 != '\0' && *s2 != '\0' && *s1 == *s2) { s1++; s2++; } if (*s2 == '\0') { return(char*)cur; } cur++; } return NULL; } int main() { char arr1[] = "abcdjskc"; char arr2[] = "cjss"; char* ret = my_strstr(arr1, arr2); if (ret == NULL) { printf("找不到\n"); } else printf("%s\n", ret); return 0; }
九、strtok函数
char * strtok ( char * str, const char * sep);
1.strtok函数使用的代码实现:
#include #include int main() { char arr[] = "95.5.4.5@111"; char* sep = ".@"; char* str = NULL; for (str = strtok(arr, sep); str != NULL; str = strtok(NULL, sep)) { printf("%s\n", str); } return 0; }
十、strerror函数
char * strerror ( int errnum );
1.strerror函数的使用:
1.1作用:将代码错误出直接打印出来。
1.2代码实现:
希望能对大家有所帮助!!!!
文章版权声明:除非注明,否则均为主机测评原创文章,转载或复制请以超链接形式并注明出处。