字串前面加l表示該字串是unicode字串。
_t是乙個巨集,如果專案使用了unicode字符集(定義了unicode巨集),則自動在字串前面加上l,否則字串不變。因此,visual
c++裡邊定義字串的時候,用
_t來保證相容性。vc支援ascii和unicode兩種字元型別,用
_t可以保證從ascii編碼型別轉換到unicode編碼型別的時候,程式不需要修改。
以下是別人的總結:
一、在字串前加乙個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,那就用後兩種方法。
別人的總結2:
你要確定你需要的字串是寬字元還是窄字元。
_t("")是說如果你定義了unicode
那麼就是l"",沒有定義就是"";以下情況用
_t()比較好,其他情況最好別用:
1,用thcar,lptstr,lpctstr等tchar資料型別的時候
2,用_tprintf之類的
_t版本執行時函式時候
3,像下面這樣有w和a版本的api,呼叫createfile的時候
#ifdef
unicode
#define createfile createfilew
#else
#define createfile
createfilea
#endif // !unicode
C 中L與 T 的區別
字串前面加l表示該字串是unicode字串。t是乙個巨集,如果專案使用了unicode字符集 定義了unicode巨集 則自動在字串前面加上l,否則字串不變。因此,visual c 裡邊定義字串的時候,用 t來保證相容性。vc支援ascii和unicode兩種字元型別,用 t可以保證從ascii編碼...
VC中 T 與L區別
一說這個話題,肯定涉及ms的字符集,先看ms對 t 其中 text 與 t 一樣 的定義 define t x t x define text x t x 如果定義了 unicode識別符號,那麼乙個稱作 t的巨集就定義如下 define t x l x如果沒有定義 unicode識別符號,則 t巨...
C 中 T 和L的區別
字串前面加l表示該字串是unicode字串。t是乙個巨集,如果專案使用了unicode字符集 定義了unicode巨集 則自動在字串前面加上l,否則字串不變。因此,visual c 裡面,定義字串的時候,用 t來保證相容性。vc支援ascii和unicode兩種字元型別,用 t可以保證從ascii編...