模拟实现“求有效字符长度”的函数my_strlen
由于主函数都一样,现统一给出
int main() { char arr[]="abcde";//5个可见(有效)字符 int len=my_strlen(arr);//len接收返回值 printf("%d\n",len); return 0; }
方法一:计数器法
int my_strlen(const char*str) { int count=0; while(*str++)//先运算后++ { count++;//计数 } return count; }
备注:此处的函数返回值按照标准理应该size_t也就是unsigned int
返回值为Int 的优缺点:
优点:不会产生由使用size_t(坑坑坑)引发的问题
缺点:不符合size_t类型的返回值的取值范围(数据类型的取值范围)
运行结果:
const作用:对于不打算修改的变量进行保护,防止被修改。
1.const写给程序员看:自解释,防止后面不小心修改str的值
2.const写给编译器看:一旦修改,立即报错,方便找bug
方法二:函数递归法
递归出口:末尾\0
不了解递归:速戳:递归
int my_strlen(const char* str) { if(*str) { return 1+my_strlen(str+1); } else { return 0; } }
方法三:指针相减法
元素个数=(指针1-指针2)/sizeof(数据类型)
int my_strlen(const char* str) { const char* start = str;//把安全(const)的指针交给安全(const)的指针 while (*str) { str++; } return str - start; }
以上三种方法都可得出结果5
备注:如果方法三为了优化代码而优化代码写成了这样是有问题的
解释:
while(str++)中把’\0’放在()内在str==‘\0’的时候,跳出循环前还是会进行从左向右执行最后一次的++操作,然后再跳出;
但是
while(*str) { str++; }
把++放在while的代码块{}内,跳出循环是不会再进行从左向右执行最后一次的++操作,而是直接跳出。
举一个例子验证:
但是这个问题可以优化到正确的答案:只用在return 返回值处再减去1
备注:我的博客中还有其他字符串函数的相关模拟实现,快来围观吧!