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

posted @ 2013-04-12 13:55  浩GE  阅读(1268)  评论(0编辑  收藏  举报