当前位置:   article > 正文

常用的字符串函数详解

字符串函数

目录

strlen()函数(求字符串长度函数)

strlen()函数简介

 strlen()函数的模拟实现

  计数器方式实现strlen()函数

递归的方式实现strlen()函数

指针-指针的方式实现strlen()函数

strcpy()函数(字符串拷贝函数)

函数简介

strcpy()函数的模拟实现

strcpy()函数实现方式1

strcpy()函数实现方式2

strcat()函数(字符串追加函数)

函数简介

strcat()函数的模拟实现

strcmp()函数(字符串比较大小函数)

函数简介

 strcmp()函数的模拟实现

 strstr()函数(字符串查找函数)

 函数简介

 strstr()函数的模拟实现


strlen()函数(求字符串长度函数

strlen()函数简介

1.字符串以'\0'为结束标志,从给定的地址向后访问字符,strlen()函数返回的是字符串中'\0'前面出现字符的个数;

  1. # include <string.h>
  2. int main()
  3. {
  4. char arr[] = "abcdef";
  5. int len = strlen(arr);
  6. printf("%d\n", len);
  7. return 0;
  8. }

运行结果:

 字符数组arr存放的元素 'a', 'b', 'c', 'd', 'e', 'f', '\0',所以结果为6.

2. 参数指向的字符必须以'\0'结束,因为如果不以'\0'作为结束标志,则strlen()函数所求的长度为随机值;

  1. # include <string.h>
  2. int main()
  3. {
  4. char arr[] = { 'a', 'b', 'c', 'd', 'e', 'f' };
  5. int len = strlen(arr);
  6. printf("%d\n", len);
  7. return 0;
  8. }

运行结果:

 这个结果是随机值,会从给定位置arr向后一直查找'\0',直到查找到'\0'为止;

3.strlen()函数的返回值为size_t,为无符号整型;

  1. int main()
  2. {
  3. const char* p1 = "abcdef";
  4. //strlen(p1)=6;
  5. const char* p2 = "xxx";
  6. //strlen(p2)=3
  7. //由于strlen()函数的返回值为unsigned int
  8. // unsigned int A=3 unsigned int B=6
  9. //A-B进行的是A的补码+(-B)的补码,最后以无符号整型输出,所以p2>p1;
  10. if (strlen(p2) - strlen(p1) > 0)
  11. {
  12. printf("p2>p1\n");
  13. }
  14. else
  15. printf("p1>p2\n");
  16. return 0;
  17. }

运行结果:

 strlen()函数的模拟实现

assert() 头文件 # include<assert.h>
1.assert是宏,不是函数;
 void assert(int expression)
2.如果expression结果为假即为0,断言失败,assert()会向标准输出装备输出一条错误消息,并调用abort()函数终止程序运行
3.如果expression表达式为真,断言成功,assert()不进行任何操作
assert()使用的注意事项:
每次断言只能检验一个条件,因为同时检查多个条件时,如果断言失败,无法直观判断是哪个条件失败;

  计数器方式实现strlen()函数

  1. # include <assert.h>
  2. int my_strlen(const char* str)
  3. {
  4. assert(str != NULL);
  5. int count = 0;
  6. while (*str != '\0')
  7. {
  8. count++;
  9. str++;
  10. }
  11. return count;
  12. }

递归的方式实现strlen()函数

  1. int my_strlen(const char* str)
  2. {
  3. assert(str != NULL);
  4. if (*str == '\0')
  5. {
  6. return 0;
  7. }
  8. else
  9. return 1 + my_strlen(str + 1);
  10. }

指针-指针的方式实现strlen()函数

指针-指针的前提两个指针指向同一块内存空间
数组是在内存空间连续存放的,并且随着下标的增大地址从低到高变化;
因为指针-指针的绝对值是中间元素的个数,只需指向'\0'处的指针-指向数组首元素的指针便可得到;

  1. int my_strlen(const char* str)
  2. {
  3. assert(str != NULL);
  4. char* p = str;//p记录起始位置的地址
  5. while (*str != '\0')
  6. {
  7. str++;
  8. }
  9. return str - p;
  10. }

strcpy()函数(字符串拷贝函数)

函数简介

1. strcpy()函数会将字符指针source所指向的字符串(包括终止字符'\0')复制到字符指针   

   destination所指向的字符串;

  1. int main()
  2. {
  3. char arr1[] = "abcdef";
  4. char arr2[] = "abc";
  5. strcpy(arr1, arr2);
  6. printf("%s\n", arr1);
  7. return 0;
  8. }

 运算结果:

 2. 原字符串必须以'\0'结束,如果不以'\0'结束,会导致程序崩溃;

  1. int main()
  2. {
  3. char arr1[] = "abcdef";
  4. char arr2[] = { 'a', 'b', 'c' };
  5. strcpy(arr1, arr2);
  6. printf("%s\n", arr1);
  7. return 0;
  8. }

运行结果:

 3. 会将源字符串的 '\0'拷贝到目标空间;

  1. int main()
  2. {
  3. char arr1[] = "abcdef";
  4. char arr2[] = "abc";
  5. strcpy(arr1, arr2);
  6. printf("%s\n", arr1);
  7. return 0;
  8. }

4.目标空间必须足够大,确保能存放源字符串;如果目标空间不够大,导致程序崩溃;

  1. int main()
  2. {
  3. char arr1[] = "xx";
  4. char arr2[] = "abcdef";
  5. strcpy(arr1, arr2);
  6. return 0;
  7. }

 运行结果:

5. 目标空间必须可变;

  1. int main()
  2. {
  3. //常量字符串不允许被修改,目标空间不可变,程序崩溃
  4. char*p = "abcdef";
  5. char arr[] = "abc";
  6. strcpy(p, arr);
  7. printf("%s\n", p);
  8. return 0;
  9. }

 运行结果:

6.strcpy()函数的返回值为目标空间的起始地址;strcpy()函数的返回类型设置为了实现链式访问;

strcpy()函数的模拟实现

strcpy()函数实现方式1

  1. char* my_strcpy(char*dest,const char* src)
  2. {
  3. assert(dest != NULL);
  4. assert(src != NULL);
  5. char* ret = dest;//记录目标空间的起始位置
  6. while (*src != '\0')
  7. {
  8. *dest = *src;
  9. dest++;
  10. src++;
  11. }
  12. //'\0'的拷贝
  13. *dest = *src;
  14. return ret;
  15. }

strcpy()函数实现方式2

  1. char* my_strcpy(char*dest, const char* src)
  2. {
  3. assert(dest != NULL);
  4. assert(src != NULL);
  5. char* ret = dest;//记录目标空间的起始位置
  6. while (*dest++ = *src++)
  7. {
  8. ;
  9. }
  10. return ret;
  11. }

strcat()函数(字符串追加函数)

函数简介

1. strcat()函数会将字符指针source所指向的字符串追加到字符指针destination所指向的字符串后面,并用 '\0'  终止字符串; 字符指针source所指向的字符串的初始字符覆盖字符指针destination所指向的字符串的'\0';

  1. int main()
  2. {
  3. char arr1[20] = "hello";
  4. char arr2[] = " world";
  5. strcat(arr1, arr2);
  6. printf("%s\n", arr1);
  7. return 0;
  8. }

运行结果:

2. 源字符串必须以'\0'结束;

3.会将源字符串'\0'拷贝到目标空间;

  1. int main()
  2. {
  3. char arr1[20] = "hello\0xxxxxxxx";
  4. char arr2[] = " world";
  5. strcat(arr1, arr2);
  6. printf("%s\n", arr1);
  7. return 0;
  8. }

4. 目标空间必须足够大,目标空间必须可变;

5. 原则上不允许字符串自己给自己追加,因为会覆盖掉'\0',从而进入死循环;

  1. int main()
  2. {
  3. char arr[20] = "world";
  4. strcat(arr, arr);
  5. printf("%s\n", arr);
  6. return 0;
  7. }

 运行结果:

strcat()函数的模拟实现

实现思路:

1. 首先找到目标空间字符串中的 '\0';

2. 然后把源字符串拷贝到目标空间;

  1. char* my_strcat(char* dest, const char*src)
  2. {
  3. assert(dest != NULL);
  4. assert(src != NULL);
  5. //记录目标空间的起始地址
  6. char* ret = dest;
  7. //先找到目标空间中的 '\0'
  8. while (*dest != '\0')
  9. {
  10. dest++;
  11. }
  12. //字符串拷贝
  13. while (*dest++= *src++)
  14. {
  15. ;
  16. }
  17. return ret;
  18. }

strcmp()函数(字符串比较大小函数)

函数简介

1.  strcmp()函数根据ASCII编码开始比较俩个字符串中的第一对字符,如果彼此相等, 继续   比较下一对字符所对应的ASCII码值,直到字符不相同或者达到终止字符'\0';

2. 函数返回值类型为 int

3. 函数返回值为0,表示俩个字符串相等;

    函数返回值为大于0的数字,表示第一个字符串大于第二个字符串;

    函数返回值为小于0的数字,表示第一个字符串小于第二个字符串;

  1. int main()
  2. {
  3. char* arr1 = "abcdef";
  4. char* arr2 = "abc";
  5. int ret = strcmp(arr1, arr2);
  6. if (ret > 0)
  7. {
  8. printf("> ");
  9. printf("ret=%d\n", ret);
  10. }
  11. else if (ret == 0)
  12. {
  13. printf("=");
  14. printf("ret=%d\n", ret);
  15. }
  16. else
  17. {
  18. printf("<");
  19. printf("ret=%d\n", ret);
  20. }
  21. return 0;
  22. }

运行结果

 strcmp()函数的模拟实现

  1. int my_strcmp(const char*s1, const char* s2)
  2. {
  3. assert(s1 != NULL);
  4. assert(s2 != NULL);
  5. while (*s1 == *s2)
  6. {
  7. if (*s1 == '\0')
  8. {
  9. return 0;
  10. }
  11. s1++;
  12. s2++;
  13. }
  14. if (*s1 > *s2)
  15. return 1;
  16. else
  17. return -1;
  18. }

 strstr()函数(字符串查找函数)

 函数简介

strstr()函数是在字符指针str1指向的字符串中查找是否含有字符指针str2所指向的字符串;

如果存在,返回str2所指向的字符串在str1指向的字符串中第一次出现的地址;

否则返回NULL;

  1. int main()
  2. {
  3. char arr1[] = "abcdefcde";
  4. char arr2[] = "cde";
  5. char*ret=strstr(arr1, arr2);
  6. if (ret == NULL)
  7. {
  8. printf("找不到子串\n");
  9. }
  10. else
  11. {
  12. printf("%s\n", ret);
  13. }
  14. return 0;
  15. }

 运行结果:

 strstr()函数的模拟实现

情况1:

如果str1指向的字符和str2指向的字符不相等,则str1指向下一个字符,str2指针指向不变,循环往复,当str1指向'\0'时,得出str1所指向的字符串不含str2所指向的字符串,此时返回NULL; 如图

 情况2:

当str1向后读取的过程中,发现两个指针指向的字符开始相等,str1继续向后读取字符,str2也向后读取字符,若str1所指向的字符和str2所指向的字符一直相等,直到str2指向 '\0', 此时可知str1所指向的字符串包含str2所指向的字符串;返回str2所指向的字符串在str1指向的字符串中第一次出现的地址;

 情况3:

当str1向后读取的过程中,发现俩个指针指向的字符开始相等,str1继续向后读取字符,str2也向后读取字符,若str1所指向的字符和str2所指向的字符不全相等,此时str2需要返回到str2所指向字符串的首字符的地址,str1需要返回到第一次和str2所指向字符相等的后一个位置;

  1. char* my_strstr(char* str1, char* str2)
  2. {
  3. assert(str1 != NULL);
  4. assert(str2 != NULL);
  5. //创建s1,s2向后查找字符,保留str1,str2是为了方便返回;
  6. char* s1 = str1;
  7. char* s2 = str2;
  8. //需要一个指针记录str1中的字符串是从哪个位置开始匹配;
  9. char* cur = str1;
  10. while (*cur != 0)
  11. {
  12. s1 = cur;
  13. //s2回到起始位置;
  14. s2 = str2;
  15. while ((*s1!='\0')&&(*s2!='\0')&&(*s1==*s2))
  16. {
  17. s1++;
  18. s2++;
  19. }
  20. //子串中所有字符查找结束
  21. if (*s2 == '\0')
  22. {
  23. return cur;
  24. }
  25. //发现*s1!=*s2,说明当前位置不可能匹配成功
  26. //需要从下一个字符开始;
  27. cur++;
  28. //从cur++的位置跳转到s1=cur;的位置
  29. //因为当前位置不可能匹配成功,s1也应该指向下一个位置;
  30. }
  31. return NULL;
  32. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/71534
推荐阅读
相关标签
  

闽ICP备14008679号