/**********************************************
函数作用:把Unicode字符串转换为Ascii字符串
参数说明:
*********lpcwszStr:要转换的Unicode字符串
*********lpcwszStr:接收转换结果的Ascii字符串
*********dwSize:用来接收转换结果的缓冲区大小
*********************************************/
BOOL NET_WCharToMByte(LPCWSTR lpcwszStr, LPSTR lpszStr, DWORD dwSize)
{
// 获得接收Ascii字符串需要的缓冲区的大小
DWORD dwMinSize;
dwMinSize = WideCharToMultiByte(CP_OEMCP, NULL, lpcwszStr, -1, NULL, 0, NULL, FALSE);
//判断给定的缓冲区的大小是否满足需要的最小缓冲区大小
if (dwSize < dwMinSize)
{
return FALSE;
}
//转换Unicode到Ascii
WideCharToMultiByte(CP_OEMCP, NULL, lpcwszStr, -1, lpszStr, dwSize, NULL, FALSE);
return TRUE;
}
/**********************************************
函数作用:把Ascii字符串转换为Unicode字符串
参数说明:
//lpcszStr:要转换的Ascii字符串
//lpwszStr:接收转换结果的Unicode字符串
//dwSize:用来接收转换结果的缓冲区大小
*********************************************/
BOOL NET_MByteToWChar
Unicode编码与多字节编码的转换
最新推荐文章于 2024-09-07 14:18:41 发布
本文介绍了两个函数,用于在Unicode和ASCII编码之间进行转换。`NET_WCharToMByte`函数将Unicode字符串转换为ASCII字符串,而`NET_MByteToWChar`函数则执行相反的操作,将ASCII字符串转换回Unicode。这两个函数都考虑了转换过程中所需的缓冲区大小,并在给定缓冲区不足时返回错误。
摘要由CSDN通过智能技术生成