好久没有编写C++程序了,最近开始编写,好手生呀。。开始编写的时候就遇到一个问题。。
编译错误。cannot convert parameter * from 'const char [**]' to 'LPCWSTR' ,于是乎就带着这个问题把字符集学习一下。
在百度百科上查了TCHAR,原来是这样的。如下文:
定义
使用原理
因为C++支持两种字符串,即常规的ANSI编码(使用""包裹)和Unicode编码(使用L""包裹),这样对应的就有了两套字符串字符串处理函数,比如:strlen和wcslen,分别用于处理两种字符串
微软将这两套字符集及其操作进行了统一,通过条件编译(通过_UNICODE和UNICODE宏)控制实际使用的字符集,这样就有了_T("")这样的字符串,对应的就有了_tcslen这样的函数
为了存储这样的通用字符,就有了TCHAR:
当没有定义_UNICODE宏时,TCHAR = char,_tcslen = strlen
当定义了_UNICODE宏时,TCHAR = wchar_t ,_tcslen = wcslen
当我们定义了UNICODE宏,就相当于告诉了编译器:我准备采用UNICODE版本。这个时候,TCHAR就会摇身一变,变成了wchar_t。而未定义UNICODE宏时,TCHAR摇身一变,变成了unsigned char。这样就可以很好的切换宽窄字符集。
tchar可用于双字节字符串,使程序可以用于中日韩等国 语言文字处理、显示。使编程方法简化。
所以在C++中,TCHAR宏统一了单双字节。降低程序员的工作负荷。。
而LPCWSTR又如何呢?
百度百科LPCWSTR如下:
MSDN 原文
An LPCWSTR isa 32-bit pointer to a constant string of 16-bit Unicode Charactor, which may be null-terminated.
This type isdeclared as follows:
typedef const wchar_t* LPCWSTR;
简要解释
LPCWSTR是一个指向unicode编码字符串的32位指针,所指向字符串是wchar型,而不是char型。
因为在VS2005以后,编码方式默认为Unicode,部分函数在使用时默认调用Unicode方式(函数名+W,exp:MessageBox+W=MessageBoxW),而非ASNI方式(函数名+A,exp:MessageBox+A=MessageBoxA)。
请看winuser.h中的声明如下:
WINUSERAPI
int
WINAPI
MessageBoxA(
__in_opt HWND hWnd,
__in_opt LPCSTR lpText,
__in_opt LPCSTR lpCaption,
__in UINT uType);
WINUSERAPI
int
WINAPI
MessageBoxW(
__in_opt HWND hWnd,
__in_opt LPCWSTR lpText,
__in_opt LPCWSTR lpCaption,
__in UINT uType);
#ifdef UNICODE
#define MessageBox MessageBoxW
#else
#define MessageBox MessageBoxA
#endif
上述声明的意思是,在unicode编码下MessageBox被编译为MessageBoxW,否则就编译为MessageBoxA。而两者的区别则看函数声明中参数2、3就可以明白了。
关于错误
如果遇到参数错误(cannotconvert parameter * from 'const char [**]' to 'LPCWSTR'),可以考虑察看声明,如果有ASNI方式的只要在函数后面加个A就可以了,或者在定义参数时把char*改为WCHAR*。
从上述可以看出 LPCWSTR是在UNICODE字符集的,是双字节字符串指针。要想字符转化为UNICODE字符集,很简单就是把字符前加上_T(""),例如 “st”->_T("st");就行了。
或者用这种方法
TCHAR sss=TCHAR("加载文件");
cfd.m_ofn.lpstrTitle=&sss;//对话框的Title
其中lpstrTitle是LPCWSTR类型的。。