目录
第一种:使用库函数strlen()
#include <stdio.h>
#include <string.h>
int main()
{
char arr[] = { "dfadfasdasd" };
int len = strlen(arr).
printf("%d\n", len);
return 0;
}
第二种:使用指针
大概思路:使用指针从数组的第一个元素地址开始,依次遍历数组每个元素,直到 '\0' (字符串的终止符号)出现,用一个计数器去记录每次遍历的次数。
#include <stdio.h>
int my_strlen(char* str)
{
int count = 0;
while(*str != '\0')
{
count++;
str++;
}
return count;
}
int main()
{
char arr[] = { "asdfasdf" };
int len = my_strlen(arr);
printf("%d\n",len);
return 0;
}
第三种:使用递归的方式
大概思路:与指针的思想有些类似,不同之处是用了递归的方法,每遍历一次,就调用一次函数,如果不是 '\0' 就+1,直到出现 '\0'。
#include <stdio.h>
int my_strlen(char* str)
{
if (*str != '\0')
{
return 1 + my_strlen(str + 1);
}
else
return 0;
}
int main()
{
char arr[] = { "asdasda" };
int len = my_strlen(arr);
printf("%d\n", len);
return 0;
}