首先,strlen碰到\0就停止, 所以长度不计上'\0'。
其次,需要一个计数器,记录长度。
#include <stdio.h>
#include <string.h>
//#define NDEBUG
//#include <assert.h>
int my_strlen(const char* str)
{
unsigned int count = 0;
//assert(str != NULL);//一个assert只检验一个条件
while (*str != '\0')
{
count++;
str++;
}
return count;
}
int main()
{
char str1[] = "abcd";
char str2[] = { 'a','b','c','\0'};
printf("%d\n", strlen(str1));
printf("%d\n", strlen(str2));
printf("%d\n", my_strlen(str1));
printf("%d\n", my_strlen(str2));
return 0;
}
const定义常变量 ,便于调试时找出错误。
为何用unsigned定义count:计数过程中都是正数。(更符合strlen库函数的定义)
通过观察,每一次字符长度数加1,下标往后移动一位。所以,能否使用递归?
这里要注意:当*str为'\0'时,要记得return 0,否则递归最后会返回随机值。
#include <stdio.h>
int my_strlen(char* str)
{
if (*str != '\0')
return 1 + my_strlen(1 + str);
else return 0;
}
int main()
{
char str[] = "i want to go home";
printf("%d\n", my_strlen(str));
return 0;
}
#include <stdio.h>
int my_strlen(char* str)
{
char* start = str;
while (*str != '\0')
str++;
return str - start;//指针相减得到两个指针之间元素个数
}
int main()
{
char str[] = "i want to go home";
printf("%d\n", my_strlen(str));
}
库函数中的strlen返回值类型是size_t,无符号数
两个无符号数相减之后的结果是无符号数。
strlen相减之后得到-1,转为无符号数是一个很大的数字,所以输出大于。
由于my_strlen中返回值为int,所以最终结果为有符号的-1,所以输出小于。
strlen一旦遇到'\0'便立即停止。
下图1中当strlen数到\0时停止计数,返回值为5
下图2、图3中为随机值,由于arr字符数组中中没有\0,所以一直往后直到碰到\0才停下
由于字符数组的不完全初始化之后,后面默认为0,在字符中也就是'\0'
因篇幅问题不能全部显示,请点此查看更多更全内容