当前位置: 代码迷 >> 综合 >> 【strlen】三种方法模拟实现strlen字符串函数
  详细解决方案

【strlen】三种方法模拟实现strlen字符串函数

热度:81   发布时间:2023-12-06 13:59:35.0
                          奇妙的字符串之旅

在这里插入图片描述

文章目录

  • 模拟实现“求有效字符长度”的函数my_strlen
      • 方法一:计数器法
      • 方法二:函数递归法
      • 方法三:指针相减法

模拟实现“求有效字符长度”的函数my_strlen

由于主函数都一样,现统一给出

int main()
{
    
char arr[]="abcde";//5个可见(有效)字符
int len=my_strlen(arr);//len接收返回值
printf("%d\n",len);
return 0;
}

方法一:计数器法

int my_strlen(const char*str)
{
    int count=0;while(*str++)//先运算后++{
    count++;//计数}return count;
}

备注:此处的函数返回值按照标准理应该size_t也就是unsigned int
返回值为Int 的优缺点:
优点:不会产生由使用size_t(坑坑坑)引发的问题
缺点:不符合size_t类型的返回值的取值范围(数据类型的取值范围)

在这里插入图片描述

运行结果:
在这里插入图片描述

const作用:对于不打算修改的变量进行保护,防止被修改。
1.const写给程序员看:自解释,防止后面不小心修改str的值
2.const写给编译器看:一旦修改,立即报错,方便找bug

方法二:函数递归法

递归出口:末尾\0

不了解递归:速戳:递归
在这里插入图片描述

在这里插入图片描述

int my_strlen(const char* str)
{
    if(*str){
    return 1+my_strlen(str+1);}else{
    return 0;}
}

方法三:指针相减法

元素个数=(指针1-指针2)/sizeof(数据类型)

int my_strlen(const char* str)
{
    const char* start = str;//把安全(const)的指针交给安全(const)的指针while (*str){
    str++;}return str - start;
}

以上三种方法都可得出结果5

备注:如果方法三为了优化代码而优化代码写成了这样是有问题的
在这里插入图片描述
解释:
while(str++)中把’\0’放在()内在str==‘\0’的时候,跳出循环前还是会进行从左向右执行最后一次的++操作,然后再跳出;
但是
while(*str)
{
str++;
}
把++放在while的代码块{}内,跳出循环是不会再进行从左向右执行最后一次的++操作,而是直接跳出。

举一个例子验证:
在这里插入图片描述

但是这个问题可以优化到正确的答案:只用在return 返回值处再减去1

备注:我的博客中还有其他字符串函数的相关模拟实现,快来围观吧!

                             关注我一起成长
  相关解决方案