您的位置:首页 > 编程语言

VC下几种转换为UNICODE字符串的办法代码

2011-04-08 17:57 295 查看
在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。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: