在vc6.0环境下,通常字符是采用ANSI方式进行编码的,而现在很多源代码或者解决之间的交互,是需要采用UNICODE字符编码的。比方说解决GDI+或者解决sqlite3的链接。那么VC下有哪些办法可以方便的将字符转换为UNICODE呢?
1、采用ATL中的USES_CONVERSION办法,然后采用A2W或者T2W方式进行转换,这种转换方式主要是在堆栈中申请内存,因此不是一种很安全的办法,容易出现溢出情况。
2、直接采用MultiByteToWideChar办法,将字符串转换为Unicode字符,在进行转换之前,有一个办法,就第一次要转换的字符串指针位置处设置为NULL,这个时候,返回的是需要转换的字符串长度,然后申请内存再进行转换。相对而言,这种方式需要较多手工编写源代码,以及手工释放。
3、解决采用ATL中的ComBSTR类,首先申请一个空的类对象,然后用Append办法将自己的字符串嵌入到该字符串类中,这个时候,在解决(BSTR)进行强制转换,就可以获取得到UNICODE字符串,该办法可以避免自己手工申请内存以及释放内存,相比较较方便。当然_bstr_t类也是类似的。
4、如果采用了CString办法,并且采用的是非ANSI方式编译源代码,那么可以用CString的SysAllocString办法,获取CString中的Unicode字符串,不过该办法需要手工释放内存单元,调用SysFreeString。
本文介绍了在VC6.0环境中从ANSI编码转换到UNICODE编码的四种常见方法:使用ATL的USES_CONVERSION宏、直接使用MultiByteToWideChar函数、利用ComBSTR类及CString的SysAllocString方法。每种方法的特点和注意事项被详细说明。

1603

被折叠的 条评论
为什么被折叠?



