1)TCHAR 转换为const wchar_t *,直接强制转换,在TCHAR前面加上(*const wchar_t)html
2)BSTR:是一个OLECHAR*类型的Unicode字符串,是一个COM字符串,带长度前缀,与VB有关,没怎么用到过。 数组
LPSTR:即 char *,指向以'/0'结尾的8位(单字节)ANSI字符数组指针 app
LPWSTR:即wchar_t *,指向'/0'结尾的16位(双字节)Unicode字符数组指针 ide
LPCSTR:即const char * 函数
LPCWSTR:即const wchar_t * 编码
LPTSTR:LPSTR、LPWSTR二者二选一,取决因而否宏定义了UNICODE或ANSI spa
LPCTSTR: LPCSTR、LPCWSTR二者二选一,取决因而否宏定义了UNICODE或ANSI,指针
以下是从MFC库中拷来的:code
#ifdef UNICODE typedef LPWSTR LPTSTR; typedef LPCWSTR LPCTSTR; #else typedef LPSTR LPTSTR; typedef LPCSTR LPCTSTR; #endif
相互转换方法:htm
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文件,其原文以下:
// force the system to re-read the mapping into shared memory // so that future invocations of the application will see it // without the user having to reboot the system WritePrivateProfileStringW( NULL, NULL, NULL, L"appname.ini" );
查了一下msdn中WritePrivateProfileStringW的原型以下:
WINBASEAPI BOOL WINAPI WritePrivateProfileStringW ( LPCWSTR lpAppName, LPCWSTR lpKeyName, LPCWSTR lpString, LPCWSTR lpFileName )
其中的每一个参数的类型都为LPCWSTR,实际中得到的文件名都为CString,问题产生。
问题分析:
LPCWSTR 是Unicode字符串指针,初始化时串有多大,申请空间就有多大,之后存贮若超过则出现没法预料的结果,这是它与CString的不一样之处。而CString是一个串类,内存空间类会自动管理。LPCWSTR 初始化以下:
LPCWSTR Name=L"TestlpCwstr";
因为LPCWSTR必须指向Unicode的字符串,问题的关键变成了Anis字符与Unicode字符之间的转换,不一样编码间的转换,经过查找资料可知,能够ATL中转换宏能够用以下方法实现:
//方法一
CString str=_T("TestStr"); USES_CONVERSION; LPWSTR pwStr=new wchar_t[str.GetLength()+1]; wcscpy(pwStr,T2W((LPCTSTR)str));
// 方法二
CString str=_T("TestStr"); USES_CONVERSION; LPWCSTR pwcStr = A2CW((LPCSTR)str);
MFC中CString和LPSTR是能够通用,其中A2CW表示(LPCSTR) -> (LPCWSTR),USER_CONVERSION表示用来定义一些中间变量,在使用ATL的转换宏以前必须定义该语句。
顺便也提一下,若是将LPCWSTR转换成CString,那就更加容易,在msdn中的CString类说明中提到了能够直接用LPCWSTR来构造CString,因此能够进行以下的转换代码:
LPCWSTR pcwStr = L"TestpwcStr";
CString str(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),使用时要注意几点: 一、只适合于进行短字符串的转换; 二、不要试图在一个次数比较多的循环体内进行转换; 三、不要试图对字符型文件内容进行转换,由于文件尺寸通常状况下是比较大的; 四、对状况 2 和 3,要使用 MultiByteToWideChar() 和 WideCharToMultiByte();