使用MultiByteToWideChar将多字节字符串转换为宽字符串。如下所示:
int MultiByteToWideChar( UINT uCodePage, DWORD dwFlags, PCSTR pMultiByteStr, int cbMultiByte, PWSTR pWideCharStr, int cchWideChar);
uCodePage参数标识了与多字节字符串关联的一个代码页值。
dwFlags参数允许你进行额外的控制。但是,一般情况下不使用这些标识。所以一般传入0值。
pMulteByteStr参数指定要转换的字符串。
cbMulteByte参数指定字符串的长度(字节数)。如果传入-1的话,函数会自动判断源字符串长度。
pWideCharStr参数指定内存缓冲区地址,存放转换好的字符串。
cchWideChar参数指定缓冲区的最大长度(字符数)。如果传入0,函数就不会进行转换,而是返回为了成功转换,缓冲区必须提供的宽字符数(包括'\0')。
一般按照以下步骤将一个多字节字符串转换为Unicode形式:
1.调用MultiByteToWideChar,为pWideCharStr参数传入NULL,为cchWideChar参数传入0,为cbMulteByte参数传入-1。
2.分配足以容纳转换后的Unicode字符串的一个内存块。他的大小是上一个MultiByteToWideChar调用的返回值乘以sizeof(wchar_t)
3.再次调用MultiByteToWideChar,这一次将缓冲区地址作为pWideCharStr参数的值传入,将第一次MultiByteToWideChar调用的返回值乘以sizeof(wchar_t)后得到的大小作为cchWideChar参数的值传入。
4.使用
5.释放
使用WideCharToMultiByte函数将Unicode转换为多字节字符串。如下所示:
int WideCharToMultiByte( UINT uCodePage, DWORD dwFlags, PCWSTR pWideCharStr, int cchWideChar, PSTR pMultiByteStr, int cbMultiByte. PCSTR pDefaultChar, PBOOL pfUsedDefaultChar);
采取的步骤与MultiByteToWideChar类似,只是返回值就是确保转换成功的字节数,无需乘法运算。
pDefaultChar和pfUsedDefaultChar只有一个字符在uCodePage指定的代码页中无表示时才会被使用到。遇到一个不能转换的宽字符时,函数便会使用pDefaultChar参数指向的字符,如果这参数为NULL,函数就会使用系统默认的字符,通常是一个问号。