Windows下字符编码方式和相关类型使用

来源:互联网 发布:elle淘宝代购真的吗 编辑:程序博客网 时间:2024/06/06 12:29
1. 两种字符集:
Windows使用两种字符集ANSI和UNICODE,前者就是通常使用的单字节方式,1个字符用1个字节存储,这种方式处理像中文这样的双字节字符不方便,容易出现半个汉字的情况。而后者是双字节方式,1个字符用两个字节存储,方便处理双字节字符。使用何种字符集,在VS中可以修改,从VS2005之后,C++项目默认编码方式是UNICODE方式。分别使用char和wchar_t来表示ANSI和UNICODE原始字符类型。

2. 两种不同的字符串:
ANSI字符串:
char path[MAX_PATH] = "c:\\Users\\Sam.zhen\\lua.dat";
UNICODE字符串:
wchar_t path[MAX_PATH] = L"c:\\Users\\Sam.zhen\\lua.dat";
L是表示字符串资源为Unicode的

自适应字符串:
TCHAR  path[MAX_PATH] = _T("c:\\Users\\Sam.zhen\\lua.dat");
_T是一个宏:在ANSI模式下:
#define __T(x)      x
在UNICODE模式下:
#define __T(x)      L ## x
也就是说:_T(x) 的行为是:在ANSI模式下,什么都不作。在UNICODE模式下,则表示字符串是UNICODE模式的。

3. 各种数据类型和他们的含义
char, wchar_t, CHAR, WCHAR, TCHAR, LPSTR, LPCSTR,LPWSTR, LPCWSTR, LPTSTR, LPCTSTR...
这如此之多的数据类型,他们的含义到底如何。下面分解之。

3.1: 字符类型
char:  字符型,是C语言标准数据类型。 由编译器决定这个类型是几个字节组成。通常情况为一个字节。
CHAR: Windows定义的字符类型,它与char相同。
WCHAR: UNICODE字符,每个字符由两个字节组成。
TCHAR:如果当前字符集是ANSI,则等同于CHAR. 如果当前字符集是UNICODE,则等同于WCHAR.

3.2: 字符串指针类型
LPSTR: 一个32bit的指向CHAR字符串的指针。typedef CHAR* LPSTR;  等于CHAR* , 即等于char*.

LPCSTR: 一个32bit的指向CHAR字符串常量的指针. typedef CONST CHAR *LPCSTR 即等于const char*

LPWSTR:一个32bit的指向UNICODE字符串的指针。  typedef  WCHAR  *LPWSTR. 即等于 wchar_t*

LPCWSTR:一个32bit的指向UNICODE字符串常量的指针。 typedef  CONST WCHAR *LPCWSTR. 即等于const wchar_t*

LPTSTR: 一个32bit的指针。ANSI字符集下,指向CHAR字符串,UNICODE模式下,指向UNICODE字符串

LPCTSTR:一个32bit的指针。ANSI字符集下,指向CHAR字符串常量,UNICODE模式下,指向UNICODE字符常量。

L:表示LONG.
P: 指针。
W: wide.
T: _T 
C: Const.



4. 各类型之间的转化
利用sprintf, wsprintf中的 %S。

When used with printf functions, specifies a wide-character string; when used with wprintf functions, specifies a single-byte–character string. Characters are printed up to the first null character or until theprecision value is reached.

可以将其相互转换:

CHAR aString[MAX_PATH] = "Sam Info: ANSI Success. 1280x720";

TCHAR tString[MAX_PATH] = _T("Sam Info: T Success. 1280x720");

WCHAR wString[MAX_PATH] = L"Sam Info: UNICODE Success. 1920x1080";

CHAR aString1[MAX_PATH] = {0};

WCHAR wString1[MAX_PATH] = {0};


printf("\nANSI String: [%s]", aString);

_tprintf(_T("\nT String:[%s]"), tString);

wprintf(L"\nUNICODE String:[%s]", wString);


sprintf(aString1, "%S", wString);

swprintf(wString1, L"%S", aString);

printf("\nUNICODE 2 ANSI String: [%s]", aString1);

wprintf(L"\nANSI 2 UNICODE String:[%s]", wString1);


5. 比较和cat:

int strcmp( const char *string1, const char *string2 ); 
int wcscmp( const wchar_t *string1, const wchar_t *string2 ); 
char *strcat( char *strDestination, const char *strSource ); 
wchar_t *wcscat( wchar_t *strDestination, const wchar_t *strSource ); 


6. 取得长度:
size_t strlen( const char *str ); 
size_t wcslen( const wchar_t *str ); 
注意:此处返回的size是字符串的字母个数。而不是字符串字节长度。wcslen()在这方面是有差别的。
字符串长度两倍于字母个数。
int lstrlen(LPCTSTR lpString );它能得到LPCTSTR的长度。也是字符个数。
0 0