计算含有汉字的字符串长度,汉字作为一个字符处理
测试结果如下:
已知汉字编码为双字节,其中首字节<0,尾字节在0-63以外(如果一个字节范围为-128-127)。
实现代码如下:
#include <iostream>
using namespace std;
int My_strlen(const char*str)
{
if(str==NULL)//检查str 的有效性
{
return NULL;
}
const char *p=str;//用于后面遍历
while(*p)//若是结束符‘\0’则结束循环
{
if(*p<0 && (*(p+1)<0 || *(p+1)>63))//中文汉字的情况
{
str++; //str移动一位,p移动移动两位,因此长度加1;
p+=2;
}
else
{
p++;
}
}
return (p-str); //长度为地址之差
}
int main()
{
char str[]="str 中国 abc 你好";
int len=My_strlen(str);
cout<<str<<endl<<len<<endl;
return 0;
}
测试结果如下: