c++截取汉字和英文混合字符串代码实例
在C++里截取字符串可以使用string.substr(),可是这个函数只能按英文来截取,
如果是汉字可能就要计算好字符个数,如果是汉字和英文混合,那就只能望洋兴叹了。
可是恰好我需要这样一个函数,于是就自己实现了一个,其中如何判断汉字和英文
参看了此处。
代码简单也无优化,若有更好的方法欢迎提出,代码如下。
#include#include #include #include #include usingnamespacestd; intis_zh_ch(charp) { /*汉字的两个字节的最高为都为1,这里采用判断最高位的方法 将p字节进行移位运算,右移8位,这样,如果移位后是0, 则说明原来的字节最高位为0,不是1那么也就不是汉字的一个字节 */ if(~(p>>8)==0) { return1;//代表不是汉字 } return-1; } stringsub(stringstr,intstart,intend=-1) { if(typeid(str)==typeid(string)&&str.length()>0) { intlen=str.length(); stringtmp=""; //先把str里的汉字和英文分开 vector dump; inti=0; while(i 0?end:dump.size();//end默认为dump.size if(start<0||start>end) printf("startiswrong"); //直接从dump里取即可 for(i=start;i<=end;i++) { tmp+=dump[i-1]; } returntmp; } else { printf("strisnotstring\n"); return""; } } intmain() { stringp="半山wuji"; cout< 以上所述是小编给大家介绍的c++截取汉字英文混合字符串详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。