收藏 分销(赏)

WideCharToMultiByte 的用法(MSDN).doc

上传人:pc****0 文档编号:9010679 上传时间:2025-03-11 格式:DOC 页数:5 大小:34KB
下载 相关 举报
WideCharToMultiByte 的用法(MSDN).doc_第1页
第1页 / 共5页
WideCharToMultiByte 的用法(MSDN).doc_第2页
第2页 / 共5页
点击查看更多>>
资源描述
国际特色 WideCharToMultiByte 函数WideCharToMultiByte一个宽字符的字符串映射到一个新的字符串。新的字符串不一定是多字节字符集。 诠释WideCharToMultiByte( UINT代码页,/ /代码页 DWORD dwFlags中,/ /性能和测绘标志 LPCWSTR lpWideCharStr,/ /宽字符字符串 cchWideChar,/ /字符串中的字符数。 LPSTR lpMultiByteStr,/ /新的字符串缓冲区 cbMultiByte,/ /缓冲区的大小 LPCSTR lpDefaultChar,/ /默认为不可映射字符 LPBOOL lpUsedDefaultChar / /设置时默认使用CHAR ); 参数 代码页 [in]指定使用的代码页进行转换。此参数可被安装或在系统中可用的任何代码页的值。有关代码页的列表,请参见代码页标识符。您还可以指定下列值之一。值含义 CP_ACP ANSI代码页 CP_MACCP Macintosh代码页 CP_OEMCP OEM代码页 CP_SYMBOL的Windows 2000/XP:符号的代码页(42) 的CP_THREAD_ACP Windows 2000/XP:当前线程的ANSI代码页 CP_UTF7 Windows 98/Me中,Windows NT 4.0和更高版本:翻译使用UTF-7。当此设置,必须为NULL lpDefaultChar和lpUsedDefaultChar CP_UTF8 Windows 98/Me中,Windows NT 4.0和更高版本:翻译使用UTF-8。当此设置,dwFlags中必须是零和两个lpDefaultChar lpUsedDefaultChar必须为NULL。 的Windows 95:根据微软的Unicode,WideCharToMultiByte还支持CP_UTF7个个CP_UTF8。 dwFlags中 [in]指定的处理未映射字符。函数执行时更快速地设置这些标志没有。下面的标志常量的定义。值含义 WC_NO_BEST_FIT_CHARS的Windows 98/Me和Windows 2000/XP的任何Unicode字符不能直接转换为多字节等值换算的默认字符(见lpDefaultChar参数)。换句话说,如果从Unicode转换为多字节和背部再次为Unicode不会产生相同的Unicode字符,使用默认的字符。 此标志可以用于本身或结合其他dwFlag选择。 WC_COMPOSITECHECK转换复合字符,到的预字符。 WC_DISCARDNS丢弃在转换过程中的非空格字符。 WC_SEPCHARS生成单独的字符转换过程中。这是默认的转换行为。 WC_DEFAULTCHAR在转换过程中的默认字符替换例外。 指定WC_COMPOSITECHECK时,功能复合字符转换到的预字符。复合字符由一个基本字符和一个非空格字符,每一个都有不同的字符值。预字符基地/非空格字符组合有一个单一的字符值。字符,电子是基础字符,重音符号标记的非空格字符。 当应用程序指定WC_COMPOSITECHECK的,它可以使用此列表中的最后三个标志(WC_DISCARDNS,的WC_SEPCHARS,WC_DEFAULTCHAR)以自定义转换的预字符的。这些标志时,判断函数的行为没有任何的预映射基地/非空格字符组合在一个宽字符的字符串。最后这三个标志只能用于,如果WC_COMPOSITECHECK标志设置。 该函数的默认行为是未映射的复合字符生成单独的的字符(WC_SEPCHARS)的。 对于下表中的代码页的dwFlags中必须为零,否则函数失败与ERROR_INVALID_FLAGS。 50220 50221 50222 50225 50227 50229 52936 54936 57002至57011 65000(UTF7,) 65001(UTF8) 42(符号) lpWideCharStr []指向宽字符字符串转换。 cchWideChar [in]指定到由lpWideCharStr参数指向的字符串中的宽字符数。如果这个值是-1,则该字符串被假定为是空终止,并自动计算长度。长度将包括空终止符。 需要注意的是如果cchWideChar是零函数失败。 lpMultiByteStr [OUT]指向接收缓冲区翻译的字符串。 cbMultiByte [in]指定的大小,以字节为单位,到由lpMultiByteStr参数指向的缓冲区。如果这个值是零,则函数返回所需缓冲区的字节数。 (在这种情况下,不使用的lpMultiByteStr缓冲区)。 lpDefaultChar []指向一个宽字符不能在指定的代码页中表示使用的字符。如果此参数为NULL,系统则使用默认值。要获取系统默认的字符,如果一个宽字符不能在指定的代码页中表示,使用的GetCPInfo或GetCPInfoEx功能。功能是更快,当两个lpDefaultChar lpUsedDefaultChar为NULL。 对于的dwFlags中提到的代码页,lpDefaultChar必须为NULL,否则函数将失败,ERROR_INVALID_PARAMETER。 lpUsedDefaultChar []指向一个标志,指示是否使用一个默认的字符。标志设置为TRUE,如果一个或多个源字符串中的宽字符不能表示在指定的代码页。否则,该标志设置为false。此参数可以为NULL。功能是更快,当两个lpDefaultChar lpUsedDefaultChar为NULL。 对于的dwFlags中提到的代码页,lpUsedDefaultChar必须为NULL,否则函数将失败,ERROR_INVALID_PARAMETER。 返回值 如果函数调用成功,非零和cbMultiByte,返回值是多少字节写入缓冲区的由lpMultiByteStr指出。这个数字包括空终止字节。 如果函数调用成功,并cbMultiByte为零,返回值是所需的大小,以字节为单位,一个缓冲区,可以接收翻译的字符串。 如果函数失败,返回值是零。为了得到扩展的错误信息,调用GetLastError。 GetLastError函数可能会返回以下错误代码之一: ERROR_INSUFFICIENT_BUFFER ERROR_INVALID_FLAGS ERROR_INVALID_PARAMETER 备注 WideCharToMultiByte函数的安全提示使用不当,可能会危及您的应用程序的安全性。调用WideCharToMultiByte函数,可以很容易地导致缓冲区溢出,因为在缓冲区的大小的数目等于字符串中的WCHARs,而离开缓冲区的大小的字节数相等。为了避免缓冲区溢出,一定要指定一个适当的数据类型的缓冲区接收缓冲区大小。欲了解更多信息,请参阅安全注意事项:国际特点。 对于需要验证的字符串,如文件,资源和用户名,请务必使用WideCharToMultiByte WC_NO_BEST_FIT_CHARS标志。此标志禁止从字符映射字符出现相似,但有很大的不同语义功能。在某些情况下,语义的变化可以是极端的,例如,标志为'∞(无穷大)映射到8(八)在某些代码页。 不可WC_NO_BEST_FIT_CHARS在Windows 95和NT4。如果您的代码必须运行在这些平台上,你可以达到同样的效果往返字符串使用MultiByteToWideChar。不往返的任何代码点是一个最合适的字符。 的lpMultiByteStr和lpWideCharStr指针必须是不一样的。如果它们是相同的,该函数将失败,GetLastError返回ERROR_INVALID_PARAMETER。 如果代码页是CP_SYMBOL的,和cbMultiByte小于cchWideChar的,没有字符被书面lpMultiByte的,。否则,如果cbMultiByte是小于cchWideChar的,cbMultiByte字符复制到由lpMultiByte指向的缓冲区。 应用程序可以使用的lpDefaultChar参数,用于转换来改变默认的字符。 如前所述,WideCharToMultiByte函数最有效地运行时lpDefaultChar lpUsedDefaultChar是NULL。下表显示了四个的组合lpDefaultChar lpUsedDefaultChar WideCharToMultiByte的行为。 lpDefaultChar lpUsedDefaultChar结果 NULL NULL没有默认的检查。这是最有效的方式使用此功能。 非NULL NULL使用指定的默认​​字符,但不设置lpUsedDefaultChar。 非NULL NULL使用系统默认的字符和如有必要设置lpUsedDefaultChar。 非空非空使用指定的默认​​字符和如有必要设置lpUsedDefaultChar。 Windows 95/98/Me的:WideCharToMultiByte是由微软的Unicode支持。要使用此功能,您必须添加特定的文件到您的应用程序,在Windows 95/98/Me的系统在微软的Unicode概述。 示例代码 举一个例子,看到寻找用户的姓名。 要求 在Windows NT 3.1和更高版本的Windows NT/2000/XP:包括。 Windows 95/98/Me的:包括在Windows 95和更高版本。 部首:申报Winnls.h;包含windows.h。 库:使用KERNEL32.LIB。 参见 Unicode和字符集概述,Unicode和字符集函数,MultiByteToWideChar -------------------------------------------------- ------------------------------ ©2005微软公司。保留所有权利。 要求 在Windows NT 3.1和更高版本的Windows NT/2000/XP:包括。 Windows 95/98/Me的:包括在Windows 95和更高版本。 部首:申报Winnls.h;包含windows.h。 库:使用KERNEL32.LIB。 参见 Unicode和字符集概述,Unicode和字符集函数,MultiByteToWideChar -------------------------------------------------- ------------------------------ ©2005微软公司。保留所有权利。 撤消修改 Alpha
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传
相似文档                                   自信AI助手自信AI助手

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服