http://haofu123.blog.163.com/blog/static/178294920096243161997/
//将wchar_t* 转成char*的实现函数如下:
char *w2c(char *pcstr,const wchar_t *pwstr, size_t len)
{
int nlength=wcslen(pwstr);
//获取转换后的长度
int nbytes = WideCharToMultiByte( 0, // specify the co
0, // no special flags to handle unmapped characters
pwstr, // wide character string to convert
nlength, // the number of wide characters in that string
NULL, // no output buffer given, we just want to know how long it needs to be
0,
NULL, // no replacement character given
NULL ); // we don't want to know if a character didn't make it through the translation
// make sure the buffer is big enough for this, making it larger if necessary
if(nbytes>len) nbytes=len;
// 通过以上得到的结果,转换unicode 字符为ascii 字符
WideCharToMultiByte( 0, // specify the co
0, // no special flags to handle unmapped characters
pwstr, // wide character string to convert
nlength, // the number of wide characters in that string
pcstr, // put the output ascii characters at the end of the buffer
nbytes, // there is at least this much space there
NULL, // no replacement character given
NULL );
return pcstr ;
}
//将char* 转成wchar_t*的实现函数如下:
//这是把asii字符转换为unicode字符,和上面相同的原理
void c2w(wchar_t *pwstr,size_t len,const char *str)
{
if(str)
{
size_t nu = strlen(str);
size_t n =(size_t)multibytetowidechar(cp_acp,0,(const char *)str,(int)nu,null,0);
if(n>=len)n=len-1;
multibytetowidechar(cp_acp,0,(const char *)str,(int)nu,pwstr,(int)n);
pwstr[n]=0;
}
}
{
wchar_t * temp=NULL;
if (str)
{
int charlength = strlen(str);
int n = (int)MultiByteToWideChar(CP_ACP, 0 ,( const char * )str, int (charlength),NULL, 0 );
temp = new wchar_t[n + 1 ];
::MultiByteToWideChar(CP_ACP, 0 ,( const char * )str, int (nu),buffer, int (n));
}
return buffer;
delete buffer;
}