windows核心编程-----Unicode和Ansi字符串的转换

使用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,函数就会使用系统默认的字符,通常是一个问号。

转载于:https://www.cnblogs.com/hao-dotnet/archive/2013/04/12/3016538.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值