模拟实现strlen包括但不限于三种方法
1.计数器实现法
2.函数递归实现法
3.指针减指针实现法
一、计数器实现法
int my_strlen(const char* str)
{
assert(str != NULL);
int count = 0;
while (*str != '\0')
{
count++;
str++;
}
return count;
}
该实现方法的核心就是设计循环中的计数器count,循环中指针str每向后移动一次,count就会加一,直到str指向\0,循环中的条件为假,循环跳出。
二、函数递归实现法
int my_strlen(const char* str)
{
if (*str == '\0')
return 0;
else return 1 + my_strlen(str + 1);
}
递归方法我觉得思路非常巧妙,让人看完之后直呼妙啊,但自己想的话确实很难想出来。
三、指针减指针实现法
int my_strlen(const char* str)
{
char* p = str;
while (*p != '\0')
p++;
return p - str;
}
这个方法主要的思路是先利用循环结构找出一个指向字符串最后‘\0’的指针,然后将该指针与字符串首元素地址str作差,利用指针的差就是两个指针之间相隔的元素的个数来获得字符串的长度。