库函数strlen的模拟实现
这里我们用三种方法实现
- 一般而言都定义一个计数器来计算字符串长度,如果不是’\0’,就加一。
- 我们也可以用递归的方式来计算,如果第一个字符不是’\0’,就用一加上后面再调用函数,直到遇到’\0’为止。
- 我们也可以用指针独特的计算方式来计算,也就是指向同一块内存的两个指针相减,就可以得到元素的个数。
#include<stdio.h>
#include<string.h>
#include<assert.h>
//指针
size_t my_strlen1(char* str)
{
assert(str);
char* p = str;
while (*str)
{
str++;
}
return str - p;
}
//递归
size_t my_strlen2(char* str)
{
assert(str);
if (*str != '\0')
{
return 1 + my_strlen2(str + 1);
}
else
{
return 0;
}
}
//一般
size_t my_strlen3(char* str)
{
size_t count = 0;
while (*str != '\0')
{
count++;
str++;
}
return count;
}
int main()
{
char arr[] = "abcdefg";
size_t ret = my_strlen1(arr);
//size_t ret = my_strlen2(arr);
//size_t ret = my_strlen3(arr);
printf("%d\n", ret);
return 0;
}