字符类型、字符指针类型、字符串字面值
字符类型:
char, wchar_t, CHAR, WCHAR, TCHAR, UCHAR, BYTE, TBYTE
char 是C语言标准数据类型,字符型。通常由编译器决定一个char对象有多少个字节组成,一般是一字节。
wchar_t 是char的Unicode版本。相当于 unsigned short。一般两个字节。
CHAR 参照定义: typedef char CHAR;
WCHAR 参照定义:typedef wchar_t WHAR;
TCAHR 通用版字符类型:在ANSI编译方式下为 char , 在Unicode 编译方式下为 wchar_t。
UCHAR 相当于unsigned char
BYTE 相当于unsigned char。在取得字符编码(00 - FF)时,非常有用。
TBYTE 通用版字符类型:在ANSI编译方式下为 char , 在Unicode 编译方式下为 wchar_t。
参照 tchar.h头文件定义:
// _UNICODE 版
#ifndef__TCHAR_DEFINED
typedefwchar_t_TCHAR;
typedefwchar_t_TSCHAR;
typedefwchar_t_TUCHAR;
typedefwchar_t_TXCHAR;
#define __TCHAR_DEFINED
#endif
typedefwchar_tTCHAR;
//非_UNICODE 版
#ifndef__TCHAR_DEFINED
typedefchar _TCHAR;
typedefsigned char _TSCHAR;
typedefunsigned char _TUCHAR;
typedefchar _TXCHAR;
#define__TCHAR_DEFINED
#endif
typedefcharTCHAR;
// 字符定义总结如下:
自适应非UNICODE UNICODE
_TCHARchar wchar_t
_TSCHARsigned char wchar_t
_TUCHARunsigned char wchar_t
_TXCHARchar wchar_t
TCHARchar wchar_t
字符指针类型:
PSTR,PWSTR,通用版: PTSTR,PTCH
LPSTR,LPWSTR,通用版:LPTSTR , LPTCH
typedef CHAR *PSTR, *LPSTR;
typedef WCHAR *PWSTR, *LPWSTR;
PCSTR,PCWSTR,通用版:PCTSTR
LPCSTR,LPCWSTR,通用版:LPCTSTR
typedef CONST CHAR *PCSTR, *LPCSTR;
typedef CONST WCHAR *PCWSTR, *LPCWSTR;
解释 通用版 非UNICODE UNICODE
字符定义 TCHAR CHAR WCHAR
字符指针 PTCHAR CHAR * WCHAR *
字符串指针 LPTCH & PTCH LPSTR & PSTR LPWSTR & PWSTR
字符串指针 LPTSTR & PTSTR LPSTR & PSTR LPWSTR & PWSTR
静态字符串指针 LPCTSTR & PCTSTR LPCSTR & PCSTR LPCWSTR & PCWSTR
字符串字面值:
参照tchar.h头文件如下定义:
// _UNICODE 版
#define__T(x)L ## x
//非_UNICODE 版
#define__T(x)x
// -----------------------------------------
#define _T(x) __T(x)
#define _TEXT(x) __T(x)
// 总结如下:
// 字符串字面值表示:
// 非UNICODE: " "
// UNICODE : L" "
// 字符串字面值表示,总结如下:
通用 非UNICODE UNICODE
__T(x) x L ## x
_T(x) x L ## x
_TEXT(x) x L ## x
参照winnt.h头件如下定义:
#ifdef UNICODE // 以下是Unicode相关定义
#define __TEXT(quote) quote // 定义字符串常量宏
#endif /* UNICODE */
#define TEXT(quote) __TEXT(quote)// 定义另一个字符串常量宏
字符串表示 __TEXT(quote) quote L ## quote字符串表示 TEXT(quote) quote L ## quote
c++字符串操作经验集
字符串处理函数总结:
标准c中的strcpy,strchr,strcat等只能用于ANSI字符串,不能正确处理Unicode字符串,因此也提供了一组补充函数,功能等价,但用于Unicode码。
我们来看看string .h字符串头文件中是怎样处理char*和wchar_t*两个字符串版本的:
char *strcat(char*,const char*);
wchar_t *wcschr(wchat_t*,const wchar_t *)
类似的还有strchr/wcschr,strcmp/wcscmp,strlen/wcslen...
ANSI 操作函数以str开头 strcpy
Unicode 操作函数以wcs开头 wcscpy
MBCS 操作函数以_mbs开头 _mbscpy
ANSI/Unicode 操作函数以_tcs开头 _tcscpy(C运行期库)
ANSI/Unicode 操作函数以lstr开头 lstrcpy(Windows函数)
各种字符串处理函数库
1 C运行库对字符串的处理:
str*系列: C运行库早期使用strlen strcpy等str*系列函数对char类型的字符串进行处理。
wcs*系列: C编译器内置了wchar_t这个16位宽字节类型后,使用新的wcslen wcscpy等wcs*系列的函数对wchar_t类型的字符串进行处理。
_tcs*系列: C运行库定义了宏_tcslen _tcscpy等_tcs*系列的宏定义,_tcs*系列函数在编译时根据是否预定义了宏_UNICODE而确定是采用wcs*系列函数,否则采用str*系列函数。
_tcs*_s系列: C运行库的最新安全字符串函数,为了防止缓冲区溢出而定义的新函数。
2 windows对字符串的处理:
Windows开发团队在winnt.h中定义了新的数据类型CHAR(char), WCHAR(wchar_t), TCHAR,TCHAR最终在编译时根据是否预定义了UNICODE宏而确定是CHAR还是WCHAR。
lstr*a系列: 在windows操作系统的Kernel32.dll中定义,处理CHAR类型的字符串,其实是对lstr*w的一层包装。
lstr*w系列: 在windows操作系统的Kernel32.dll中定义,处理WCHAR类型的字符串。
lstr*系列: lstr*系列函数也是在编译时才根据是否预定义了UNICODE宏来确定采用lstr*a系列函数,还是lstr*w系列函数。
个人推荐用lstr*系列,因为这个是windows api,这样写出来的程序不用把C运行库链接进来。
有个需要注意的是,C运行库的_UNICODE和Windows的UNICODE,两个宏,要么同时定义,要么同时不定义。C运行库前缀下划线是为了遵守那个该死的C++标准(对于不属于C++标准的宏加下划线),而Windows没有遵守那个标准
字符(串)之间的转换
1.使用ATL的字符串转换宏,可以实现不同类型的字符串转换。
在宏名称里面,分别用A,W,T代表ANSI字符串,Unicode字符串,以及TCHAR字符串。
并分别用CA,CW,CT来代表相应的const字符串。
对ANSI字符串进行转换操作的宏有A2W,A2T,A2CW,A2CT。
对Unicode字符串进行转换操作的宏有W2A,W2T,W2CA,W2CT。
对TCHAR字符串进行转换操作的宏有T2W,T2A,T2CW,T2CA。
*需要注意的是: 在使用以上宏的时候,必须在程序中定义如下宏,
USES_CONVERSION;
2. 字符串与其他类型之间的转换
字符串和INT的相互转换
通过atoi,_wtoi,_ttoi可以分别把ANSI,Unicode和TCHAR字符串转换成INT。
通过_itoa,_itow,_itot可以分别把INT转换成ANSI,Unicode和TCHAR字符串。
字符串和LONG的相互转换
通过atol,_wtol,_ttol可以分别把ANSI,Unicode和TCHAR字符串转换成LONG
通过_ltoa,_ltow,_ltot可以分别把INT转换成ANSI,Unicode和TCHAR字符串。
字符串和DOUBLE的相互转换
通过atof,_wtof,_ttof可以分别把ANSI,Unicode和TCHAR字符串转换成DOUBLE
通过_fcvt 可以把DOUBLE数值转换为ANSI字符串。
ANSI 和 UNICODE 的函数对应表
ANSI UNICODE 通用
(char.h) (wchar.h) (tchar.h)
char wchar_t TCHAR
char * wchar_t * PTCHAR (PTSTR,LPWSTR,PWSTR,WCHAR)
printf wprintf _tprintf
scanf wscanf _tscanf
atoi _wtoi _ttoi
atol _wtol _ttol
itoa _itow _itot
ltoa _ltow _ltot
atof _wtof _tstof
strlen wcslen _tcslen
strcat wcscat _tcscat
strcpy wcscpy _tcscpy
strcmp wcscmp _tcscmp
附:C语言字符串函数详解 strcpy、strcmp、strcat、strlen、strstr
http://write.blog.csdn.net/postedit/7300418
atoi, itoa 字符串转换函数源代码
http://blog.csdn.net/ltag0110rtag/article/details/7363919