大家在看本文之前如果还不了解strlen函数的话
可以参考一下我写的这篇博客:【C库函数】qsort函数详解
1、给模拟函数起个名字
先给模拟实现的函数起个名吧,就叫my_strlen
然后创建一个字符型数组,把数组地址传给my_strlen,并用len变量接收my_strlen的返回值。
int main() { char str[] = "abcdef"; int len = my_srlen(str); printf("%d",len); return 0; }
2、定义my_strlen函数,并写出my_strlen的原型
因为my_strlen接受的是str[]数组首元素地址,所以要用指针来接手,同时my_strlen不会改变数组内字符的内容,所以我用const来修饰一下,保护指针所指向的内容。最后返回类型我们可以设计成int,当然我们也可以像库里面的一样设计成size_t类型(无符号整数)
//size_t strlen(const char* str) int my_strlen(const char* str) { }
3、实现my_strlen函数功能
my_stlen中参数是指针要想字符内容,则解引用地址就行了,定义一个整型变量,每当判断该地址所指向字符不为‘\0’时,变量++指针++。
int my_strlen(const char* str) { int count = 0; while (*str) { count++; str++; } return count; }
同时,为了避免接受空指针,我还需添加一个检测函数assert
int my_strlen(const char* str) { assert(str != NULL); int count = 0; while (*str) { count++; str++; } return count; }
完整实现代码如下
#include<stdio.h> #include<assert.h> int my_strlen(const char* str) { assert(str != NULL); int count = 0; while (*str) { count++; str++; } return count; } int main() { char str[] = "abcdef"; int len = my_strlen(str); printf("%d", len); return 0; }