前言:
本博客共分为strlen函数的介绍和模拟实现两部分,其中,共介绍了strlen的两种模拟实现方式:指针-指针、计数器法
strlen函数的介绍及其应用:
- strlen是求字符串长度的,统计的是'\0'之前的字符个数(不包括'\0')
- 题外话:一个汉字占两个字符
- strlen的头文件是:#include <string.h>
- strlen的返回类型是size_t(size_t也就是unsigned int),无符号整型,所以任何一个strlen的返回值都应该是正数
- 提示:每段代码的注释都具有详细解释功能
strlen的应用:
#include <stdio.h> #include <string.h>//strlen的头文件 int main() { char arr[] = "abcdef";//字符串里隐藏了一个'\0',故该数组共7个元素 char arr1[] = "abc\0def";//遇到'\0'就会停下 char arr2[] = { 'a','b','c' };//要把'\0'自己手动放进去(避免随机) printf("%d\n", strlen(arr));//6 //随让该数组一共七个元素,但是打印出来答案却是6,反映了strlen不会计算'\0' printf("%d\n", strlen(arr1));//3 printf("%d\n", strlen(arr2));//没有'\0'是随机值 return 0; }
注意:
//size_t-->unsigned int 无符号整型,都是正数
//因为个数不可能是负数
#include <stdio.h>
#include <string.h>
int main()
{
if (strlen("abc") - strlen("abcdef") > 0)
//所以即使这里是3-6=-3;
//因为strlen的返回类型是无符号数,所以无符号数减无符号数还是一个无符号数;
//会被当做一个正数来看,所以>0
printf(">\n");//打印>
else
printf("<\n");
return 0;
}
strlen的模拟实现:
strlen函数的设计:size_t strlen(const char * str);
计数器法:(此法比较粗暴)
思路:这种方法就是单纯的通过设置一个变量,让其跟随指针的后移而不停加加,直到找到了'\0'为止
#include <stdio.h>
#include <assert.h>//assert头文件
size_t my_strlen(const char* arr)
{
assert(arr);//防止arr是空指针
int count = 0;
while (*arr)
{
count++;
arr++;
}
return count;
}
int main()
{
char arr[] = "adsdjsfhfjkf";
int len = my_strlen(arr);
printf("%d\n", len);
return 0;
}
指针-指针法:
思路:因为strlen求的是从起始位置开始数一直到'\0'的字符个数,所以便可以想到用指针-指针的方式来模拟,因为两个指针相减的结果也是两个指针之间的元素个数,于是便可以写代码了。
#include <stdio.h>
#include <assert.h>
size_t my_strlen(const char* arr)
{
assert(arr);
const char* start = arr;
while (*arr)
{
arr++;
}
return arr - start;//指针-指针
}
int main()
{
char arr[] = "dasjsfdgfdkghkf";
int len = my_strlen(arr);//15
printf("%d\n", len);
return 0;
}