C++ _T()函數和_L()函數介紹


  _T("")是一個宏,他的作用是讓你的程序支持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_t Str[] = L"Hello World!";
這個就是雙子節存儲字符了。

        _T是一個適配的宏~


#ifdef _UNICODE的時候
_T就是L
沒有#ifdef _UNICODE的時候
_T就是ANSI的。

比如

LPTSTR lpStr = new TCHAR[32];
TCHAR* szBuf = _T("Hello");
以上兩句使得無論是在UNICODE編譯條件下都是正確編譯的。

而且MS推薦你使用相匹配的字符串函數。
比如處理LPTSTR或者LPCTSTR 的時候,不要用strlen ,而是要用_tcslen

否則在UNICODE的編譯條件下,strlen不能處理 wchar_t*的字符串。

T是非常有意思的一個符號(TCHAR、LPCTSTR、LPTSTR、_T()、_TEXT()...),它表示使用一種中間類型,既不明確表示使用 MBCS,也不明確表示使用 UNICODE。那到底使用哪種字符集?編譯的時候才決定


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM