• <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>

            brucejini

            關(guān)于char, wchar_t, TCHAR, _T(),L,宏 _T、TEXT,_TEXT、L

             

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

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

            它實際定義在<string.h>里:typedef unsigned short wchar_t。

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

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

            其中,寬字節(jié)類型每個變量占用2個字節(jié),故上述數(shù)組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,那么就不應(yīng)該使用ANSI的strXXX函數(shù)或者Unicode的wcsXXX函數(shù)了,而必須使用tchar.h中定義的_tcsXXX函數(shù)。

            以strcpy函數(shù)為例子,總結(jié)一下:
             

            //如果你想使用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了!他分析了原因后總結(jié):如 果您正開始一個新的項目,請無論如何也要頂住壓力,直接使用UNICODE編碼!切記!您只需要對您的組員進行10分鐘的培訓,記住strcpy用 wcscpy,sprintf用swprintf代替,常數(shù)前加L,就可以了!它不會花您很多時間的,帶給您的是穩(wěn)定和安全!相信偶,沒錯的!!

            一、 在字符串前加一個L作用:
               如  L"我的字符串"    表示將ANSI字符串轉(zhuǎn)換成unicode的字符串,就是每個字符占用兩個字節(jié)。
              strlen("asd")   =   3;  
              strlen(L"asd")   =   6;
              二、  _T宏可以把一個引號引起來的字符串,根據(jù)你的環(huán)境設(shè)置,使得編譯器會根據(jù)編譯目標環(huán)境選擇合適的(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,那就用后兩種方法。

            posted on 2009-10-15 14:16 路人甲 閱讀(591) 評論(0)  編輯 收藏 引用 所屬分類: 轉(zhuǎn)載

            公告

            Locations of visitors to this page

            導航

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統(tǒng)計

            常用鏈接

            留言簿

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            博客收藏

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            A级毛片无码久久精品免费| 99蜜桃臀久久久欧美精品网站 | 国产免费久久精品99久久| 潮喷大喷水系列无码久久精品| 97久久天天综合色天天综合色hd| 国内精品伊人久久久久影院对白| 蜜桃麻豆WWW久久囤产精品| 九九久久自然熟的香蕉图片| 97超级碰碰碰碰久久久久| 久久热这里只有精品在线观看| 国产亚洲美女精品久久久久狼| 亚洲精品成人网久久久久久| 久久96国产精品久久久| 亚洲第一极品精品无码久久| 久久久久久国产精品无码下载 | 伊人久久大香线蕉无码麻豆| 久久精品国产亚洲av高清漫画| 日日狠狠久久偷偷色综合免费| 成人国内精品久久久久一区| 狠狠色噜噜色狠狠狠综合久久| 久久强奷乱码老熟女网站| 精品国产福利久久久| 少妇高潮惨叫久久久久久| 精品久久亚洲中文无码| 国产精品VIDEOSSEX久久发布| 久久精品国产亚洲AV无码娇色 | 色综合久久中文色婷婷| 久久国产精品成人片免费| 久久精品aⅴ无码中文字字幕不卡| 91精品国产高清久久久久久91| 国内精品久久久久久野外| 69久久精品无码一区二区| 久久亚洲欧美国产精品| 久久久久久国产精品美女| 久久久无码精品亚洲日韩蜜臀浪潮 | 久久精品国产免费| 久久精品国产一区| 成人午夜精品久久久久久久小说| 久久免费精品一区二区| 国产叼嘿久久精品久久| 久久亚洲精品无码观看不卡|