• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            唐吉訶德

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              5 Posts :: 75 Stories :: 3 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(2)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            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,那就用后兩種方法

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

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

                  它實際定義在<string.h>里: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是定義在該頭文件中的宏,它視你是否定義了   
                 NICODE宏而定義成:
            定義了_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函數為例子,總結一下:
             

            //如果你想使用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"));

             
            char是C語言標準數據類型,字符型,至于由幾個字節組成通常由編譯器決定,一般一個字節。Windows為了消除各 編譯器的差別,重新定義了一些數據類型,你提到了另外幾個類型都是這樣。
            CHAR為單字節字符。
            還有個WCHAR為Unicode字符,即不論中英文,每 個字有兩個字節組成。
            如果當前編譯方式為ANSI(默認)方式,TCHAR等價于CHAR,
            如果為Unicode方式,TCHAR等價于WCHAR。
            在當 前版本LPCSTR和LPSTR沒區別,即以零結尾的字符串指針,相當于CHAR *。


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

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

            它實際定義在<string.h>里: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函數為例子,總結一下:
             

            //如果你想使用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,那就用后兩種方法。

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

            posted on 2010-08-23 16:46 心羽 閱讀(782) 評論(0)  編輯 收藏 引用 所屬分類: C/C++
            精品人妻伦九区久久AAA片69| 久久中文精品无码中文字幕| 久久人人爽人人爽人人av东京热 | 久久人人爽人人爽人人av东京热| 亚洲精品久久久www| 国产成人精品三上悠亚久久| 久久精品国产第一区二区三区| 99久久99这里只有免费的精品| 精品乱码久久久久久夜夜嗨| 囯产极品美女高潮无套久久久| 久久不射电影网| 免费无码国产欧美久久18| 69国产成人综合久久精品| 久久久久久极精品久久久 | 久久人人爽人人爽人人AV东京热| 99久久中文字幕| 精品久久久久久久久免费影院| 国产午夜精品理论片久久影视| 中文字幕无码久久精品青草 | 久久人人爽人人爽人人AV东京热 | 亚洲精品无码久久毛片| 91久久精一区二区三区大全| 久久无码精品一区二区三区| 精品国际久久久久999波多野| 怡红院日本一道日本久久 | 久久精品中文无码资源站| 久久香蕉国产线看观看猫咪?v| 久久精品人人做人人爽97| 国产成人精品久久| 中文字幕久久波多野结衣av| 国产精品99久久久久久www| 中文字幕无码久久久| 久久精品a亚洲国产v高清不卡| 人人狠狠综合久久亚洲高清| 久久永久免费人妻精品下载| 久久无码国产| 久久97久久97精品免视看| 欧洲精品久久久av无码电影 | 久久久久99精品成人片欧美| 亚洲第一永久AV网站久久精品男人的天堂AV | 久久婷婷久久一区二区三区|