VC++裡面定義字串的時候,用_T來保證相容性。VC++支援ascii和unicode兩種字元類型,用_T可以保證從ascii編碼類別型轉換到unicode編碼類別型的時候,程式不需要修改。
如果將來你不打算升級到unicode,那麼也不需要_T。
_t("hello world")
在ansi的環境下,它是ansi的,如果在unicode下,那麼它將自動解釋為雙位元組字元串,既unicode編碼。
這樣做的好處,不管是ansi環境,還是unicode環境,都適用。
那麼在VC++中,字串_T("ABC")和一個普通的字串"ABC"有什麼區別呢?
_T("ABC")
如果定義了unicode,它將表示為L"ABC",每個字元為16位,寬字元串。
如果沒有定義unicode,它就是ascii的"ABC",每個字元為8位。
相當於
#ifdef _UNICODE
#define _T("ABC") L"ABC"
#else
#define _T("ABC") "ABC"
#endif
_T("ABC")中的一個字元和漢字一樣,佔兩個位元組,而在"ABC"中,英文字元佔一個位元組,漢字佔兩個位元組。
一、 在字串前加一個L作用:
如 L"我的字串" 表示將ANSI字串轉換成unicode的字串,就是每個字元佔用兩個位元組。
strlen("asd") = 3;
strlen(L"asd") = 6;
二、 _T宏可以把一個引號引起來的字串,根據你的環境設定,使得編譯器會根據編譯目標環境選擇合適的(Unicode還是ANSI)字元處理方式
如果你定義了UNICODE,那麼_T宏會把字串前面加一個L。這時 _T("ABCD") 相當於 L"ABCD" ,這是寬字元串。
如果沒有定義,那麼_T宏不會在字串前面加那個L,_T("ABCD") 就等價於 "ABCD"
三、TEXT,_TEXT 和_T 一樣的
如下面三語句:
TCHAR szStr1[] = TEXT("str1");
char szStr2[] = "str2";
VC _T的用途
2009-09-23 16:28
from:http://blog.csdn.net/athemon/archive/2008/08/29/2849584.aspx VC++裡面定義字串的時候,用_T來保證相容性。VC++支援ascii和unicode兩種字元類型,用_T可以保證從ascii編碼類別型轉換到unicode編碼類別型的時候,程式不需要修改。 如果將來你不打算升級到unicode,那麼也不需要_T。 _t("hello world") 在ansi的環境下,它是ansi的,如果在unicode下,那麼它將自動解釋為雙位元組字元串,既unicode編碼。 這樣做的好處,不管是ansi環境,還是unicode環境,都適用。 那麼在VC++中,字串_T("ABC")和一個普通的字串"ABC"有什麼區別呢? _T("ABC") 如果定義了unicode,它將表示為L"ABC",每個字元為16位,寬字元串。 如果沒有定義unicode,它就是ascii的"ABC",每個字元為8位。 相當於 #ifdef _UNICODE #define _T("ABC") L"ABC" #else #define _T("ABC") "ABC" #endif _T("ABC")中的一個字元和漢字一樣,佔兩個位元組,而在"ABC"中,英文字元佔一個位元組,漢字佔兩個位元組。 一、 在字串前加一個L作用: 如 L"我的字串" 表示將ANSI字串轉換成unicode的字串,就是每個字元佔用兩個位元組。 strlen("asd") = 3; strlen(L"asd") = 6; 二、 _T宏可以把一個引號引起來的字串,根據你的環境設定,使得編譯器會根據編譯目標環境選擇合適的(Unicode還是ANSI)字元處理方式 如果你定義了UNICODE,那麼_T宏會把字串前面加一個L。這時 _T("ABCD") 相當於 L"ABCD" ,這是寬字元串。 如果沒有定義,那麼_T宏不會在字串前面加那個L,_T("ABCD") 就等價於 "ABCD" 三、TEXT,_TEXT 和_T 一樣的 如下面三語句: TCHAR szStr1[] = TEXT("str1"); char szStr2[] = "str2"; WCHAR szStr3[] = L("str3"); 那麼第一句話在定義了UNICODE時會解釋為第三句話,沒有定義時就等於第二句話。 但二句話無論是否定義了UNICODE都是產生一個ANSI字串,而第三句話總是產生UNICODE字串。 為了程式的可移植性,建議都用第一種表示方法。 但在某些情況下,某個字元必須為ANSI或UNICODE,那就用後兩種方法 |
WCHAR szStr3[] = L("str3");
那麼第一句話在定義了UNICODE時會解釋為第三句話,沒有定義時就等於第二句話。
但二句話無論是否定義了UNICODE都是產生一個ANSI字串,而第三句話總是產生UNICODE字串。
為了程式的可移植性,建議都用第一種表示方法。
但在某些情況下,某個字元必須為ANSI或UNICODE,那就用後兩種方法