C语言中的MultiByteToWideChar和WideCharToMultiByte函数是用来在宽字符和多字节字符之间进行转换的。下面是它们的用法:
int MultiByteToWideChar( UINT CodePage, // 字符编码方式 DWORD dwFlags, // 转换标志 LPCSTR lpMultiByteStr, // 多字节字符串 int cbMultiByte, // 多字节字符串的字节数 LPWSTR lpWideCharStr, // 宽字符字符串 int cchWideChar // 宽字符字符串的字符数);CodePage:指定字符编码方式,一般使用CP_UTF8表示UTF-8编码,也可以使用其他编码方式。dwFlags:用来指定转换标志,一般可以使用0表示默认转换。lpMultiByteStr:指向要转换的多字节字符串。cbMultiByte:多字节字符串的字节数。lpWideCharStr:指向转换后的宽字符字符串的缓冲区。cchWideChar:指定宽字符字符串的缓冲区大小(以字符为单位)。WideCharToMultiByte:int WideCharToMultiByte( UINT CodePage, // 字符编码方式 DWORD dwFlags, // 转换标志 LPCWSTR lpWideCharStr, // 宽字符字符串 int cchWideChar, // 宽字符字符串的字符数 LPSTR lpMultiByteStr, // 多字节字符串 int cbMultiByte, // 多字节字符串的字节数 LPCSTR lpDefaultChar, // 用于表示无法转换的字符的默认字符 LPBOOL lpUsedDefaultChar // 用于指示是否使用了默认字符);CodePage:指定字符编码方式,一般使用CP_UTF8表示UTF-8编码,也可以使用其他编码方式。dwFlags:用来指定转换标志,一般可以使用0表示默认转换。lpWideCharStr:指向要转换的宽字符字符串。cchWideChar:宽字符字符串的字符数。lpMultiByteStr:指向转换后的多字节字符串的缓冲区。cbMultiByte:指定多字节字符串的缓冲区大小(以字节为单位)。lpDefaultChar:用于表示宽字符无法转换为多字节字符时的默认字符。lpUsedDefaultChar:指示是否使用了默认字符的标志。注意事项:
在使用这两个函数前,需要先调用SetDefaultDllDirectories函数,并使用LOAD_LIBRARY_SEARCH_SYSTEM32标志来加载所需的动态链接库kernel32.dll。在转换字符串之前,应该确保目标字符串的缓冲区足够大,以免发生缓冲区溢出。转换后的字符串可能会以null-terminated形式结束,需要根据情况进行处理。示例代码:
#include <windows.h>int main(){ char mbstr[100] = "Hello, 你好!"; wchar_t wcstr[100]; // 将多字节字符串转换为宽字符字符串 MultiByteToWideChar(CP_UTF8, 0, mbstr, -1, wcstr, sizeof(wcstr)/sizeof(wcstr[0])); // 在宽字符字符串后面添加一些文本 wcscat(wcstr, L" 世界!"); // 将宽字符字符串转换为多字节字符串 char mbstr2[100]; WideCharToMultiByte(CP_UTF8, 0, wcstr, -1, mbstr2, sizeof(mbstr2)/sizeof(mbstr2[0]), NULL, NULL); printf("%s\n", mbstr2); return 0;}这个例子中,首先将一个多字节字符串转换为宽字符字符串,然后在宽字符字符串后面添加一些文本,最后再将宽字符字符串转换为多