關於char, wchar_t, TCHAR, _T(),L,宏 _T、TEXT,_TEXT、L

關於char, wchar_t, TCHAR, _T(),L,宏 _T、TEXT,_TEXT、L

 

char :單字節變量類型,最多表示256個字符,

wchar_t :寬字節變量類型,用於表示Unicode字符,

它實際定義在裏:typedef unsigned short wchar_t。

爲了讓編譯器識別Unicode字符串,必須以在前面加一個“L”,定義寬字節類型方法如下:

    wchar_t c = `A' ; 
wchar_t * p = L"Hello!" ; 
wchar_t a[] = L"Hello!" ;

其中,寬字節類型每個變量佔用2個字節,故上述數組a的sizeof(a) = 14

 

TCHAR / _T( ) :


如果在程序中既包括ANSI又包括Unicode編碼,需要包括頭文件tchar.h。TCHAR是定義在該頭文件中的宏,它視你是否定義了_UNICODE宏而定義成: 
定義了_UNICODE:    typedef wchar_t TCHAR ; 
沒有定義_UNICODE: typedef char TCHAR ;

#ifdef UNICODE 
typedef char TCHAR; 
#else 
typede wchar_t TCHAR; 
#endif 
_T( )也是定義在該頭文件中的宏,視是否定義了_UNICODE宏而定義成: 
定義了_UNICODE:    #define _T(x) L##x 
沒有定義_UNICODE: #define _T(x) x 
注意:如果在程序中使用了TCHAR,那麼就不應該使用ANSI的strXXX函數或者Unicode的wcsXXX函數了,而必須使用tchar.h中定義的_tcsXXX函數。

以strcpy函數爲例子,總結一下:

 

Code


//如果你想使用ANSI字符串,那麼請使用這一套寫法:  
char szString[100];  
strcpy(szString,"test");  
//如果你想使用Unicode字符串,那麼請使用這一套:  
wchar_t szString[100];  
wcscpy(szString,L"test");  
//如果你想通過定義_UNICODE宏,而編譯ANSI或者Unicode字符串代碼:  
TCHAR szString[100];  
_tcscpy(szString,_TEXT("test"));

CSDN:superarhow說:不要再使用TCHAR和_T了!他分析了原因後總結:如果您正開始一個新的項目,請無論如何也要頂住壓力,直接使用UNICODE編碼!切記!您只需要對您的組員進行10分鐘的培訓,記住strcpy用 wcscpy,sprintf用swprintf代替,常數前加L,就可以了!它不會花您很多時間的,帶給您的是穩定和安全!相信偶,沒錯的!!

 

一、 在字符串前加一個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,那就用後兩種方法。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章