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

            山寨:不是最好的,是最適合我們的!歡迎體驗(yàn)山寨 中文版MSDN

            Blog @ Blog

            當(dāng)華美的葉片落盡,生命的脈絡(luò)才歷歷可見。 -- 聶魯達(dá)

            常用鏈接

            統(tǒng)計(jì)

            積分與排名

            BBS

            Blog

            Web

            最新評論

            規(guī)范化編程:ANSI和UNICODE的使用

            到底什么是ANSI,什么是UNICODE呢?其實(shí)這是兩種不同的編碼方式標(biāo)準(zhǔn),ANSI中的字符采用8bit,而UNICODE中的字符采用16bit8bitANSI編碼只能表示256種字符,表示26個(gè)英文字母是綽綽有余的,但是表示漢字,韓國語,日語等有著成千上萬個(gè)字符的非西方字符肯定就不夠了,正是如此才引入了UNICODE標(biāo)準(zhǔn)。

            在軟件開發(fā)中,特別是使用C語言的一些有關(guān)字符串處理的函數(shù),ANSIUNICODE是區(qū)分是用的,那么ANSI類型的字符和UNICODE類型的字符如何定義,如何使用呢?ANSIUNICODE又如何轉(zhuǎn)換呢?

            一.定義部分:

            ANSI     char str[1024];   可用字符串處理函數(shù):strcpy( ), strcat( ), strlen( )等等。UNICODEwchar_t str[1024]可用字符串處理函數(shù)

             

            二.可用函數(shù):

            ANSI:即 char 可用字符串處理函數(shù):strcat( ),strcpy( ), strlen( )等以str打頭的函數(shù)。

            UNICODE:即wchar_t 可用字符串處理函數(shù):wcscat(),wcscpy(),wcslen()等以wcs打頭的函數(shù)。

             

            三.系統(tǒng)支持

            Windows 98 :只支持ANSI

            Windows 2k :既支持ANSI又支持UNICODE

            Windows CE :只支持UNICODE

            說明

            1. COM里面只支持UNICODE

            2. Windows 2000整個(gè)OS系統(tǒng)都是基于UNICODE的,為此在windows 2000下使用ANSI是需要付出代價(jià)的,雖然在編碼上不用任何的轉(zhuǎn)換,但是這種轉(zhuǎn)化是隱藏的,是占用系統(tǒng)資源的(CPU,內(nèi)存)。

            3. Windows 98下必須使用UNICODE,則需要自己手動的編碼切換。

             

            三.如何區(qū)分:

            在我們軟件開發(fā)中往往需要即支持ANSI又支持UNICODE,不可能在要求類型轉(zhuǎn)換的時(shí)候,重新改變字符串的類型,和使用于字符串上的操作函數(shù)。為此, 標(biāo)準(zhǔn)的C 運(yùn)行期庫和Windows 提供了宏定義的方式。

            C語言里面提供了 _UNICODE宏(有下劃線),在Windows里面提供了UNICODE宏(無下劃線),只要定了_UNICODE宏和UNICODE宏,系統(tǒng)就會自動切換到UNICODE版本,否則,系統(tǒng)按照ANSI的方式進(jìn)行編譯和運(yùn)行。

            只定義了宏并不能實(shí)現(xiàn)自動的轉(zhuǎn)換,他還需要一系列的字符定義支持。

            1. TCHAR

            如果定義了UNICODE宏則TCHAR被定義為wchar_t

            typedef wchar_t     TCHAR;

            否則TCHAR被定義為char

            typedef char            TCHAR;

            2. LPTSTR

            如果定義了UNICODE宏則LPTSTR被定義為LPWSTR

            typedef LPTSTR     LPWSTR;

            否則TCHAR被定義為char

            typedef LPTSTR     LPSTR;

             

            說明: 在使用字符串常量的時(shí)候需要使用_TEXT(“MyStr”)來支持系統(tǒng)的自動轉(zhuǎn)換。

            posted on 2008-08-30 14:16 isabc 閱讀(441) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            廣告信息(免費(fèi)廣告聯(lián)系)

            中文版MSDN:
            歡迎體驗(yàn)

            aaa级精品久久久国产片| 潮喷大喷水系列无码久久精品| 欧美久久综合性欧美| 精品国产福利久久久| 久久精品成人免费国产片小草| 天天影视色香欲综合久久| 亚洲精品无码久久千人斩| 久久亚洲国产欧洲精品一| 一本色道久久综合狠狠躁篇| 久久久久久毛片免费播放| 精品无码人妻久久久久久| 久久久久亚洲av无码专区导航| 97精品伊人久久久大香线蕉 | 久久久久久综合网天天| 久久国产成人精品麻豆| 久久伊人亚洲AV无码网站| 久久99精品久久久久久齐齐 | 日本一区精品久久久久影院| 久久精品国产亚洲AV不卡| 一本一本久久A久久综合精品 | 亚洲色大成网站WWW久久九九| 国产∨亚洲V天堂无码久久久| 综合久久久久久中文字幕亚洲国产国产综合一区首| 狠狠色丁香久久婷婷综合_中| 精品国产综合区久久久久久| 日韩精品久久久久久免费| 中文字幕无码久久人妻| 国产亚洲精午夜久久久久久 | 国产精品久久99| 亚洲人成网亚洲欧洲无码久久| 久久婷婷人人澡人人| 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲高清不卡 国产成人精品久久亚洲 | 久久免费高清视频| 男女久久久国产一区二区三区| 亚洲国产成人久久笫一页| 蜜桃麻豆www久久国产精品| 国産精品久久久久久久| 久久精品国产亚洲Aⅴ蜜臀色欲| 久久青青草原综合伊人| 久久精品国产亚洲麻豆| 亚洲天堂久久精品|