1.用count计数器
#include<stdio.h>
#include<assert.h>
size_t my_strlen(char* str)
{
assert(str != NULL);
int count = 0;
while (*str != '\0')
{
str++;
count++;
}
return count;
}
int main()
{
char arr[] = "abcdef";
int len = my_strlen(arr);
printf("%d\n", len);
system("pause");
return 0;
}
2.用递归(不能使用count计数器)
//不能创建临时变量
#include<stdio.h>
int my_strlen(const char* str)
{
if (*str == '\0')
{
return 0;
}
else
{
return 1 + my_strlen(str + 1);
}
}
int main()
{
char arr[] = "abcdefg";
int len = my_strlen(arr);
printf("%d\n", len);
system("pause");
return 0;
}
递归实际上就是一个先递推再回归的过程
3.指针减指针
#include<stdio.h>
int my_strlen(const char* str)
{
char* p = str;
while (*p != '\0')
{
p++;
}
return p - str;
}
int main()
{
char arr[] = "abcdefg";
int len = my_strlen(arr);
printf("%d\n", len);
system("pause");
return 0;
}
指针减指针是指两个指针只想空间的中间相差的元素个数