wchar_t与char转换
1\
wchar_t是Unicode用的宽字符类型。用双字表示的字符.汉字字符即为双字。 可以用Win32Api的MultiByteToWideChar/WideCharToMultiByte或C运行库的mbstowcs/wcstombs系列函数对wchar_t* 和 char* 之间进行转换。
a:
wchar_t是unicode字符和char不能直接转换
可用win Api
int MultiByteToWideChar(UINT CodePage, DWORD dwFlags, LPCSTR lpMultiByteStr, int cchMultiByte, LPWSTR lpWideCharStr, int cchWideChar)
转换
b:
要借助于AnsiString与WideString互换;
char *s= "中华人民共和国 ";
wchar *p=Widetring(s).BSTR();
====================================
wchar_t *p=L "中华人民共和国 ";
char *s=AnsiString(p).c_str();
2\
wchar_t与char转换
原文地址:http://hi.baidu.com/gchrist/blog/item/29a138f533383e24bd310934.html
环境:Dev cpp 平台i386
C++标准中,wchar_t是宽字符类型,每个wchar_t类型占2个字节,16位宽。汉字的表示就要用到wchar_t 。char,我们都知道,占一个字节,8位宽。其实知道了这个以后,要在wchar_t 和 char两种类型之间转换就不难实现了。wchar_t 转换为char 的代码如下: 有如下的wchar_t和char变量:wchar_t w_cn = '中'; char c_cn[2] = {'0'} ;
char *C2W(wchar_t w_cn , char c_cn[2]){ //following code convert wchar to char c_cn[0] = w_cn >> 8 ; c_cn[1] = w_cn ; c_cn[2] = '\0'; return c_cn ;} 其中需要注意的是一个16位的wchar_t需要用两个8位的char来存储之。我们可以发现另外一个问题,wchar_t的高位字节应该存储在char数组的低位字节。(这里没有仔细研究了,觉得怪怪的)。 这是完成了wchar_t到char的转化,char到wchar_t的转换类似。C++中,你要想这样:cout<<w_cn<<endl;打印wchar_t,那是不行的。why?我想是wchar_t类型没有重载<<运算符吧。要显示,我的方法是:char *W2C(const wchar_t *pw , char *pc){//cout<<*pw<<endl; //这样是不能正确显示的,你可以试试看显示的是什么 *pc++ = *pw >> 8 ; *pc = *pw ; return 0 ;} char *wstr2cstr(const wchar_t *pwstr , char *pcstr, size_t len){ char *ptemp = pcstr ; if(pwstr!=NULL && pcstr!=NULL) { size_t wstr_len = wcslen(pwstr) ; len = (len > wstr_len ) ? wstr_len : len ; while( len -- > 0) { W2C(pwstr , pcstr); pwstr++ ; pcstr +=2 ; //和我们开始说的一样+2,不是+1 } *pcstr = '\0'; return ptemp ; } return 0 ;} int main(int arg , char *argv[]){ wchar_t pwstr[] = {'我' , '是' , '中' , '国' , '人'}; char *pcstr = (char *)new char[2 * wcslen(pwstr)+1] ; memset(pcstr , 0 , 2 * wcslen(pwstr)+1 ); wstr2cstr(pwstr , pcstr , wcslen(pwstr)) ; str.assign (pcstr); cout<<str<<endl; delete []pcstr ;}