1)
TCHAR 转换为const wchar_t *,直接强制转换,在TCHAR前面加上(*constwchar_t)
2)
BSTR:是一个OLECHAR*类型的Unicode字符串,是一个COM字符串,带长度前缀,与VB有关,没怎么用到过。
LPSTR:即 char *,指向以'/0'结尾的8位(单字节)ANSI字符数组指针
LPWSTR:即wchar_t *,指向'/0'结尾的16位(双字节)Unicode字符数组指针
LPCSTR:即const char *
LPCWSTR:即const wchar_t *
LPTSTR:LPSTR、LPWSTR两者二选一,取决于是否宏定义了UNICODE或ANSI
LPCTSTR: LPCSTR、LPCWSTR两者二选一,取决于是否宏定义了UNICODE或ANSI,
如下是从MFC库中拷来的:
#ifdef UNICODE typedef LPWSTR LPTSTR; typedef LPCWSTR LPCTSTR;
#else typedef LPSTR LPTSTR; typedef LPCSTR LPCTSTR; #endif
相互转换方法:
LPWSTR->LPTSTR: W2T();
LPTSTR->LPWSTR: T2W();
LPCWSTR->LPCSTR: W2CT();
LPCSTR->LPCWSTR: T2CW();
ANSI->UNICODE: A2W();
UNICODE->ANSI: W2A();
3)
LPWSTR转为LPCSTR
LPCSTR=CW2A(LPWSTR);
4)
CString与LPCWSTR的转化(http://www.cnblogs.com/foolboy/archive/2005/07/25/199869.html)
问题起因:
在写WritePrivateProfileString写.ini配置文件时在msdn中看到,如果想要写得配置信息即时生效必须在之前使用WritePrivateProfileStringW来re-read一下目标.ini文件,其原文如下:
//
forcethesystemtore-readthemappingintosharedmemory
//
sothatfutureinvocationsoftheapplicationwillseeit
//
withouttheuserhavingtorebootthesystem
WritePrivateProfileStringW(NULL,NULL,L
"
appname.ini
"
);
查了一下msdn中WritePrivateProfileStringW的原型如下:
WINBASEAPIBOOLWINAPIWritePrivateProfileStringW(
LPCWSTRlpAppName,
LPCWSTRlpKeyName,
LPCWSTRlpString,
LPCWSTRlpFileName)
其中的每个参数的类型都为LPCWSTR,实际中获得的文件名都为CString,问题产生。
问题分析:
LPCWSTR 是Unicode字符串指针,初始化时串有多大,申请空间就有多大,以后存贮若超过则出现无法预料的结果,这是它与CString的不同之处。而CString是一个串类,内存空间类会自动管理。LPCWSTR初始化如下:
LPCWSTRName
=
L
"
TestlpCwstr
"
;
由于LPCWSTR必须指向Unicode的字符串,问题的关键变成了Anis字符与Unicode字符之间的转换,不同编码间的转换,通过查找资料可知,可以ATL中转换宏可以用如下方法实现:
//
方法一
CStringstr
=
_T(
"
TestStr
"
);
USES_CONVERSION;
LPWSTRpwStr
=
new
wchar_t[str.GetLength()
+
1
];
wcscpy(pwStr,T2W((LPCTSTR)str));
//
方法二
CStringstr
=
_T(
"
TestStr
"
);
USES_CONVERSION;
LPWCSTRpwcStr
=
A2CW((LPCSTR)str);
MFC中CString和LPSTR是可以通用,其中A2CW表示(LPCSTR) -> (LPCWSTR),USER_CONVERSION表示用来定义一些中间变量,在使用ATL的转换宏之前必须定义该语句。
顺便也提一下,如果将LPCWSTR转换成CString,那就更加容易,在msdn中的CString类说明中提到了可以直接用LPCWSTR来构造CString,所以可以进行如下的转换代码:
LPCWSTRpcwStr
=
L
"
TestpwcStr
"
;
CStringstr(pcwStr);
问题总结:
在头文件<atlconv.h>中定义了ATL提供的所有转换宏,如:
A2CW(LPCSTR)
->
(LPCWSTR)
A2W(LPCSTR)
->
(LPWSTR)
W2CA(LPCWSTR)
->
(LPCSTR)
W2A(LPCWSTR)
->
(LPSTR)
所有的宏如下表所示:
A2BSTR |
OLE2A |
T2A |
W2A |
A2COLE |
OLE2BSTR |
T2BSTR |
W2BSTR |
A2CT |
OLE2CA |
T2CA |
W2CA |
A2CW |
OLE2CT |
T2COLE |
W2COLE |
A2OLE |
OLE2CW |
T2CW |
W2CT |
A2T |
OLE2T |
T2OLE |
W2OLE |
A2W |
OLE2W |
T2W |
W2T |
上表中的宏函数,非常的有规律,每个字母都有确切的含义如下:
2 |
to 的发音和 2 一样,所以借用来表示“转换为、转换到”的含义。 |
A |
ANSI 字符串,也就是 MBCS。 |
W、OLE |
宽字符串,也就是 UNICODE。 |
T |
中间类型T。如果定义了 _UNICODE,则T表示W;如果定义了 _MBCS,则T表示A |
C |
const 的缩写 |
利用这些宏,可以快速的进行各种字符间的转换。使用前必须包含头文件,并且申明USER_CONVERSION;使用 ATL 转换宏,由于不用释放临时空间,所以使用起来非常方便。但是考虑到栈空间的尺寸(VC 默认2M),使用时要注意几点:
1、只适合于进行短字符串的转换;
2、不要试图在一个次数比较多的循环体内进行转换;
3、不要试图对字符型文件内容进行转换,因为文件尺寸一般情况下是比较大的;
4、对情况 2 和 3,要使用 MultiByteToWideChar() 和 WideCharToMultiByte();