_T

_T

_T是一個宏,作用是讓你的程式支持Unicode編碼。

因為Windows使用兩種字元集ANSI和UNICODE,

前者就是通常使用的單位元組方式,

但這種方式處理像中文這樣的雙位元組字元不方便,

容易出現半個漢字的情況。

而後者是雙位元組方式,方便處理雙位元組字元。

基本介紹

  • 外文名:_T
  • 性質:科技
  • 類別:計算機
  • 屬於:編程
定義,作用,

定義

_T("")是一個宏,定義於tchar.h下。
#define __T(x) L ## x
#define _T(x) __T(x)

作用

他的作用是讓你的程式支持Unicode編碼,
因為Windows使用兩種字元集ANSI和UNICODE,
前者就是通常使用的單位元組方式,
但這種方式處理像中文這樣的雙位元組字元不方便,
容易出現半個漢字的情況。
而後者是雙位元組方式,方便處理雙位元組字元。
Windows NT的所有與字元有關的函式都提供兩種方式的版本,而Windows 9x只支持ANSI方式。
如果你編譯一個程式為ANSI方式,
_T實際不起任何作用。
而如果編譯一個程式為UNICODE方式,則編譯器會把"Hello"字元串以UNICODE方式保存。_T和_L的區別在於,_L不管你是以什麼方式編譯,一律以UNICODE方式保存。
LPSTR:32bit指針指向一個字元串,每個字元占1位元組
LPCSTR:32-bit指針指向一個常字元串,每個字元占1位元組
LPCTSTR:32-bit指針指向一個常字元串,每字元可能占1位元組或2位元組,取決於Unicode是否定義
LPTSTR:32-bit指針每字元可能占1位元組或2位元組,取決於Unicode是否定義
L是表示字元串資源為Unicode的。
比如
wchar_tStr[] = L"Hello World!";
這個就是雙位元組存儲字元了。
_T是一個適配的宏~
#ifdef _UNICODE的時候
_T就是L
沒有#ifdef _UNICODE的時候
_T就是ANSI的。
比如
LPTSTR lpStr = new TCHAR[32];
TCHAR* szBuf = _T("Hello");
以上兩句使得無論是在UNICODE編譯條件下還是在ANSI編譯條件下都是正確編譯的。
而且MS推薦你使用相匹配的字元串函式
比如處理LPTSTR或者LPCTSTR的時候,不要用strlen ,而是要用_tcslen
否則在UNICODE的編譯條件下,strlen不能處理wchar_t*的字元串。

相關詞條

熱門詞條

聯絡我們