strlen()函数:
strlen所作的是一个计数器的工作,它从内存的某个位置(可以是字符串开头,中间某个位置,甚至是某个不确定的内存区域)开始扫描,直到碰到第一个字符串结束符’\0’为止,然后返回计数器值(长度不包含’\0’)。
那么我们就来尝试一下自己动手写一个strlen函数。
方法一:
#include <stdio.h>
#include <assert.h>
int my_strlen(const char* s)
{
char* p = s;
assert(p != NULL);//断言,确保指针的有效性
int count = 0;
while (*p != '\0')
{
count++;
p++;
}
return count;
}
int main()
{
char str[] = "abcdefg";
int len = my_strlen(str);
printf("%d\n", len);
return 0;
}
运行结果:
方法二:
使用递归来编写strlen函数。
#include <stdio.h>
int my_strlen(const char* s)
{
char* p = s;
if (*p == '\0')
return 0;
return 1 + my_strlen(p + 1);
}
int main()
{
char str[] = "abcdefg";
int len = my_strlen(str);
printf("%d\n", len);
return 0;
}
运行结果:
方法三:
因为 指针 - 指针 = 数组大小,
所以我们也可以这样写strlen函数。
#include <stdio.h>
#include <assert.h>
int my_strlen(const char* s)
{
char* p = s;
assert(p != NULL);//断言,保证指针的有效性
char* start = p;
char* end = p;
while (*end != '\0')
{
end++;
}
return end - start;
}
int main()
{
char str[] = "abcdefg";
int len = my_strlen(str);
printf("%d\n", len);
return 0;
}
运行结果: