爲了搞清這些函數,就必須理請幾種字符類型的寫法。char就不用說了,先說一些wchar_t。wchar_t是Unicode字符的數據類型,它實際定義在<string.h>裏:
typedef unsigned short wchar_t;
不能使用類似strcpy這樣的ANSI C字符串函數來處理wchar_t字符串,必須使用wcs前綴的函數,例如wcscpy。爲了讓編譯器識別Unicode字符串,必須以在前面加一個“L”,例如:
wchar_t *szTest=L"This is a Unicode string.";
下面在看看TCHAR。如果你希望同時爲ANSI和Unicode編譯的源代碼,那就要include TChar.h。TCHAR是定義在其中的一個宏,它視你是否定義了_UNICODE宏而定義成char或者wchar_t。如果你使用了TCHAR,那麼就不應該使用ANSI的strXXX函數或者Unicode的wcsXXX函數了,而必須使用TChar.h中定義的_tcsXXX函數。另外,爲了解決剛纔提到帶“L”的問題,TChar.h中定義了一個宏:“_TEXT”。
以strcpy函數爲例子,總結一下:
.如果你想使用ANSI字符串,那麼請使用這一套寫法:
char szString[100];
strcpy(szString,"test");
.如果你想使用Unicode字符串,那麼請使用這一套:
wchar_t szString[100];
wcscpyszString,L"test");
.如果你想通過定義_UNICODE宏,而編譯ANSI或者Unicode字符串代碼:
TCHAR szString[100];
_tcscpy(szString,_TEXT("test"));
參考資料:Windows核心編程,Jeffrey Richter