工程由于使用ASCII码编码,ASCII码定义了255个字符.所以呢,字母就在'A'~'Z','a'~'z'之间,数字就是48~58之间.但是由于汉字是双字节的,其字节不在0~255内,所以可以单独判断汉字。这样就避免了换工程成Unicode之后一大堆新的错误发生。 if(CString[i] & 0x80) //如果为真则为汉字.CString[i+1]为汉字后半部分
下面引用一段前辈的代码说明下:
来源于:http://bbs.csdn.net/topics/250089618 原作者:wangdeqie
希望对遇到同样问题的同学能有所帮助!//帮你写了个,运行环境:VC6 #include <afx.h> #include <iostream.h> void main() { cout<<"输入你想截取的位数(一个汉字占2位):"<<endl; int n; cin>>n; CString str="机可大法的kjjkjf大幅降低kddjfd"; if (str[n-1] & 0x80) { str=str.Mid(0,n+1); cout<<str<<endl; return; } str=str.Mid(0,n); cout<<str<<endl; }