用字符数组实现
最基础的写法,循环逐一判断数组中的字符是否为空字符,若遇到空字符则说明实际字符已读取完毕
unsigned int MyStrlen(char str[])
{
unsigned int len = 0;
for(int i = 0;str[i]!='\0';i++)
{
len++;
}
return len;
}
用字符指针实现
形参为一个字符指针,字符指针指向的是字符串的首地址,通过间接寻址运算符*获取指向的字符内容,判断是否为空字符,若不为空字符,则将指针加一继续寻址,直到遇到空字符
unsigned int MyStrlen(char *pStr)
{
unsigned int len = 0;
for( ; *pStr!='\0';pStr++)
{
len++;
}
return len;
}
实现优化
因为在这个函数中我们不需要修改字符数组中的内容,因此为了防止字符数组被误修改,在形参类型说明符前加一个const修饰符,表示是一个指向字符常量的指针变量,保护指针变量指向的内容不被修改。
空字符'\0'的ASCII码值为0,所以*pStr!='\0'又可写为*pStr!=0,即*pStr为真,所以在for循环判断中又可直接用*pStr表示,优化后的代码如下
unsigned int MyStrlen(const char *pStr)
{
unsigned int len = 0;
for( ;*pStr;pStr++)
{
len++;
}
return len;
}
而根据运算符优先级和结合性又可将*pStr;和pStr++这两个表达式合并为一个表达式*pStr++,所以这个for循环可以直接用while代替
unsigned int MyStrlen(const char *pStr)
{
unsigned int len = 0;
while(*pStr++)
{
len++;
}
return len;
}
优化到这里就结束了吗,还没有,这个用来记录长度的len变量也可以去掉。定义一个字符指针用来记录字符数组的首地址,在循环结束后,原指针已经指向了字符数组中第一个空字符,用这个地址减去首地址即为字符数组的实际字符个数,最终优化后的代码如下
unsigned int MyStrlen(const char *pStr)
{
const char *start = pStr;
while(*pStr)
{
pStr++;
}
return pStr - start;
}