模拟实现strlen的三种方法

一、strlen()的工作原理

二、模拟实现strlen的三种方法

  1. 计数器方法
  2. 指针-指针
  3. 递归的方法

三、库函数实现strlen的思路

四、库函数的strlen同上面模拟实现strlen的区别

一、strlen工作原理

strlen函数工作原理:是计算字符串str的长度,直到空字符串结束,但不包含空字符串。(即该长度算至/0结束,但不包含/0)

通过以下代码能有一个直观的感受:

int main(){
  char arr[]="abcdef";
  int len=strlen(a);//"abcdef"即  'a' 'b' 'c' 'd' 'e' 'f' '\0'
                          //计算的是'\0'之前的元素个数
  printf("%d\n",len);     // 输出结果为6
  return 0;  

}

模拟实现strlen的三种方法

以上则为strlen的工作原理

即strlen计算的是字符串内'\0'之前的元素个数。(不包含'\0')

二、模拟实现strlen的三种方法

  1. 计数器方法
  2. 指针-指针
  3. 递归的方法

我们通过上述得知strlen的工作原理,那么我们接下来根据其工作原理实现strlen.
共有以下三种方式去实现:

ps:只有sizeof(数组名)&(数组名),此时代表的是整个数组的地址,其余时候
数组名 仅仅代表首元素地址。在本文中,数组名 只代表首元素地址。

int my_strlen(){}    //要实现的功能,如下三种方式
int main(){
  char arr[]="abcdef";
  int len=my_strlen(a);                      
  printf("%d\n",len);     
  return 0;  

}

1.计数器方式(创建了临时变量)

思路如下:将arr传递到my_strlen中,我们创建一个变量 count ,当 *arr!=0 时则 count +1, arr也+1 ,此时 *arr='b' ,arr和count再同时+1, 直到 *a=='\0'时,
我们返回 count 的值,此时的 count 的值为元素的个数。

图解如下:
模拟实现strlen的三种方法

算法如下:

int my_strlen(const char *str){
  int count=0;
  while(*str!='\0'){    //当为'\0'时,即while(0),条件为假,退出循环
    count++;
    str++;
}
  return count;
}

2.指针-指针(创建了临时变量)

思路如下:创建指针p指向arr,当p!='\0'时,p加上1,直到p='\0',用
指针p-指针arr,此时的指针p代表的是'\0'的地址,指针arr代表的是首
元素地址,两者相减得到的值为两地址之间的元素个数。

图解如下:
模拟实现strlen的三种方法

当p走到'\0'的地址时, p-arr=元素的个数

实现代码如下:

 int my_strlen(const char*str){
   const char*p=str;

   while(*p){
     p++;
 }
   return p-str;
}

3.递归(不创建临时变量)
思路如下:通过递归的思想。

图解吐下:
模拟实现strlen的三种方法

ps:递归的基本思想是把一个大型复杂的问题层层转化为一个与原问题相似的规
模较小的问题来求解。

算法如下:

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

三、参考库函数如何实现strlen

模拟实现strlen的三种方法

对比自身用指针实现strlen,代码更为简洁,将 while(*p){p++;} 精简为
while(*p++);

图解如下:
模拟实现strlen的三种方法

ps:如何查看库函数实现strlen。可看链接:如何查看库函数实现的某些函数(strlen,strcmp,strcpy等)

四、库函数的strlen同上面模拟实现strlen的区别

可通过如下代码进行区别:

#include<string.h>
#include<stdio.h>
int main(){
    if(strlen("abc")-strlen("abcdef")>0)
    {printf("hehe\n");
        }
     else
        {printf("haha\n");
        }
}

很显然,我们应该是打印 haha,但结果是hehe,为什么打印的是hehe
因为在strlen()的函数声明如下:size_t strlen(const char*str)

定义的类型是size_t,那么size_t又是什么类型
通过如下操作可知:
模拟实现strlen的三种方法

可知size_t是无符号整型,于是:无符号整型-无符号整型=无符号整型
于是打印的是hehe

我们模拟实现函数strlen返回的是int,于是当我们
调用my_strlen时,打印的便是haha,效果如下
模拟实现strlen的三种方法

原文链接:https://www.cnblogs.com/zzao/p/17128270.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:模拟实现strlen的三种方法 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • 荣耀畅玩8c怎么截长图?荣耀畅玩8c滚动截屏方法

    荣耀畅玩8c是一款性价比比较高的手机,它内置了截屏功能来满足用户的需求,但是有时我们需要截取长图或进行滚动截屏,下面将详细讲解“荣耀畅玩8c怎么截长图?荣耀畅玩8c滚动截屏方法”的完整攻略。 荣耀畅玩8c截取长图方法 荣耀畅玩8c提供了系统自带的截屏功能,但是它只能截取屏幕内的内容,对于需要截取较长的页面就不太适用了。下面介绍一种轻松截取长图的方法。 打开需…

    C 2023年5月23日
    00
  • C++中类的成员函数及内联函数使用及说明

    下面我就来为您详细讲解C++中类的成员函数及内联函数使用及说明的攻略。 类成员函数的定义 在C++中,类的成员函数可以在类的定义中进行声明,并在类外定义函数实现。类成员函数的定义格式如下: class ClassName { public: ReturnType functionName(ParameterList); //… }; ReturnType…

    C 2023年5月22日
    00
  • C语言实现socket简单通信实例

    下面我将为你讲解“C语言实现socket简单通信实例”的完整攻略。 1. 什么是Socket? Socket(套接字)是计算机网络中对TCP/IP协议的抽象,是一组接口和规范,用于实现网络通信或者进程间通信。利用Socket,程序员可以方便的开发出网络应用程序,实现进程之间的网络通信和资源共享。 2. C语言实现Socket通信要点 在C语言中,我们可以通过…

    C 2023年5月23日
    00
  • C#操作SQLite数据库方法小结

    关于C#操作SQLite数据库方法小结,我可以提供以下攻略: 1. 安装SQLite 在使用SQLite之前,需要先安装SQLite数据库,在Windows上可以从官方网站下载SQLite安装程序进行安装。 2. 创建SQLite数据库 为了进行SQLite数据库的操作,需要使用以下命令创建连接并打开数据库: SQLiteConnection conn = …

    C 2023年5月22日
    00
  • C++ auto类型说明符

    C++自动类型说明符(auto)是一种C++11引入的新特性,可以让编译器自动推导出变量的数据类型。使用auto关键字可以帮助简化代码,减少代码冗余,提升阅读性和代码的可维护性。 auto类型说明符的使用方法 在C++11中,使用auto类型说明符定义变量时,可以这样写: auto 变量名 = 初始化表达式; 其中,变量名可以是任意合法的变量名,而初始化表达…

    C 2023年5月23日
    00
  • C++入门之模板基础讲解

    下面我将为您提供“C++入门之模板基础讲解”的完整攻略。 概述 C++模板是一种让程序员能够编写独立于类型和数据结构的通用代码的工具,其中最常见的模板是函数模板和类模板。我们可以使用模板来封装算法和数据结构,提高代码的可重用性和可扩展性。 函数模板 函数模板是一种定义通用函数的方式,可以重用相同的代码来处理不同类型的数据。使用函数模板的方式非常简单,我们只需…

    C 2023年5月23日
    00
  • C++学习之异常机制详解

    C++学习之异常机制详解 什么是异常机制 C++的异常机制可以帮助我们处理程序运行时可能出现的意外状况,而在这些意外状况中,有些可能无法在程序设计时被完全预见,这个时候异常机制就可以帮助我们在程序出现异常时,优雅地终止程序,同时保证程序的稳定性。 C++异常机制的使用 C++的异常机制通过 try 和 catch 块来实现,其中 try 块用来包含可能会抛出…

    C 2023年5月23日
    00
  • Visual Studio Code配置C、C++环境并编写运行的方法

    接下来我将为您提供Visual Studio Code配置C、C++环境并编写运行的方法的完整攻略。 Visual Studio Code配置C、C++环境并编写运行的方法 1. 安装Visual Studio Code 首先,我们需要安装Visual Studio Code,推荐从官网上下载最新版本。 2. 安装C、C++编译器 Windows环境中,推荐…

    C 2023年5月23日
    00
合作推广
合作推广
分享本页
返回顶部