1 前言
首先大家得清楚一件事,一般在网上提出问题的人大部分使用的都是VC,那么你就应该知道,在VC下编程,工程属性中有一属性Charecter Set属性,其值可以设置为Use Multi-Byte Charecter Set 和 Use Unicode Charecter Set 这两种选择,具默认情况下工程是采用了Use Unicode Charecter Set选项.如我使用的VS2010的工程属性中如下:
VC在处理CString类型字符时,在这两种不种选择的处理结果也是完全不一样的,而网上那么答复大都是针对假设提问者是使用了Use Mult-Byte Chracter Set的前提下,但大多提这个问题的人都是使用了后者的情况的人.
暂且将Use Mult-Byte Chracter Set称之为宽字节字符模式,而Use Unicode Charecter Set称之为Unicode编码模式.
2 宽字节字符模式
首先讨论一下宽字符字符模式下的CStirng与Char *之间的互转,在这种情况下互换很简单:
2.1 CString –>char *
如下:
CString str1 ="123";
char *p =(LPSTR)(LPCSTR)str1;
但好像官方并不建议这么做,而建议采用下面这种方式:
CString str1 ="123";
char *t1 =str1.GetBuffer(str1.GetLength());
str1.ReleaseBuffer();
//do something with t1
网上也有人说是这样t1 =str1.GetBuffer(0);但其实我在实测时并没发现str1.GetBuffer(str1.GetLenth())与str.GetBuffer(0)返回值有啥区别
GetBuffer的参数nMinBufLength为最小缓冲区长度,但实际结果没啥区别
2.2 char * –>CString
char *str ="aaaa"
CString str1(str);
//...
2.3 CString –>int
在宽字符字符模式下,这个非常简单:
CString str1 ="123";
int i =atoi(str1);
//do something with i
2.4 int –>CString
int i =100;
CString str;
str.Format("%d",i);
//...
**3 Unicode编码模式
3.1 CString –>char *
在这种情况下,上述所说的转化全是浮云,目前只发现可以用WideCharToMultiByte函数来实现.
如下 :
CString str1 =_T("123");
int len =WideCharToMultiByte(CP_ACP,0,str1,-1,NULL,0,NULL,NULL);
char *ptxtTemp =new char[len +1];
WideCharToMultiByte(CP_ACP,0,str1,-1,ptxtTemp,len,NULL,NULL );
//...
delete[] ptxtTemp;
3.2 char * –>CString
还是可以如下:
char *p ="test";
CString str(p);
//...
3.3 CString –>int
在这种情况下atoi不再适用,其实可以用swscanf,如下:
CString str2 =_T("100");
int i;
swscanf(str2,_T("%d"),&i);
3.4 int –>CString
这个其实最简单了,如下:
int j =100;
CString str3;
str3.Format(_T("%d"),j);
4 结束
另外,有关ANSI与Unicode之间的转换及UTF-8与Unicode之间的转换可以参与下面这个链接:
http://www.cnblogs.com/gakusei/articles/1585211.html