标签:style class blog code http tar
函数原型:
int MultiByteToWideChar( UINT CodePage, DWORD dwFlags, LPCSTR lpMultiByteStr, int cchMultiByte, LPWSTR lpWideCharStr, int cchWideChar );
补充:如果ANSI代码页允许在不同的计算机上不相同,甚至在单台计算机上不一样,将会导致数据崩溃。为了代码页一致性,应用程序应该使用Unicode编码,如UTF-8或者UTF-16,而不是使用特殊的代码页,除了早期标准或者数据格式化不允许使用Unicode编码。在特殊情况下,有些函数不允许使用Unicode编码,应用程序应在协议允许的情况下在数据流中用合适的编码名称标识。在HTML、XML、HTTP等文件中都允许标识,但TEXT文本不允许这样做。
函数功能:MultiByteToWideChar是一种windows API 函数,该函数映射一个字符串到一个宽字符(unicode)的字符串。由该函数映射的字符串没必要是多字节字符组。
参数:
CP_ACP: ANSI字符集; CP_MACCP: Macintosh代码页; CP_OEMCP: OEM代码页; CP_SYMBOL: 符号字符集(42); CP_THREAD_ACP: 当前线程ANSI代码页; CP_UTF7: 使用UTF-7转换; CP_UTF8: 使用UTF-8转换。
MB_PRECOMPOSED:
通常使用预作字符——就是说,由一个基本字符和一个非空字符组成的字符只有一个单一的字符值。这是缺省的转换选择。不能与MB_COMPOSITE值一起使用。
MB_COMPOSITE:
通常使用组合字符——就是说,由一个基本字符和一个非空字符组成的字符分别有不同的字符值。不能与MB_PRECOMPOSED值一起使用。
MB_ERR_INVALID_CHARS:
如果函数遇到无效的输入字符,它将运行失败,且GetLastErro返回ERROR_NO_UNICODE_TRANSLATION值。
MB_USEGLYPHCHARS:
使用象形文字替代控制字符。
char* pszMultiByte = "Holle"; //strlen(pwsUnicode)=5 int iSize; wchar_t* pwszUnicode ; //返回接受字符串所需缓冲区的大小,已经包含字符结尾符‘\0‘ iSize = MultiByteToWideChar(CP_ACP, 0, pszMultiByte , -1, NULL, 0); //iSize =wcslen(pwsUnicode)+1=6 pwszUnicode = (wchar_t *)malloc(iSize*sizeof(wchar_t)); //不需要 pwszUnicode = (wchar_t *)malloc((iSize+1)*sizeof(wchar_t)) MultiByteToWideChar(CP_ACP, 0, pszMultiByte , -1, pwszUnicode , iSize);
参考:
http://www.cnblogs.com/vranger/p/3792791.html
http://baike.baidu.com/view/1907282.htm?fr=aladdin
函数 MultiByteToWideChar() 详解,布布扣,bubuko.com
标签:style class blog code http tar
原文地址:http://www.cnblogs.com/vranger/p/3793205.html