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

            99久久国语露脸精品国产| 久久中文字幕人妻熟av女| 伊人久久大香线蕉综合Av | 9999国产精品欧美久久久久久| 婷婷久久综合九色综合98| 欧美日韩成人精品久久久免费看| 久久这里都是精品| 久久国产高清字幕中文| 国产成年无码久久久免费| 色综合久久综精品| 91麻豆国产精品91久久久| 99久久免费国产精品| 亚洲色欲久久久综合网| 久久久久国产精品三级网| 久久青青草原精品影院| 怡红院日本一道日本久久| 午夜精品久久久久久久| 99久久国产宗和精品1上映| 一本久久久久久久| AV无码久久久久不卡蜜桃| 久久久无码精品亚洲日韩蜜臀浪潮| 久久精品青青草原伊人| 久久精品国产亚洲AV影院| 狠狠人妻久久久久久综合| 国产综合成人久久大片91| 国产精品久久久久AV福利动漫| 伊人久久精品无码av一区| 国产精品久久久久久久久久影院| 久久人人爽人人澡人人高潮AV | 色妞色综合久久夜夜| 久久国产香蕉一区精品| 狠狠人妻久久久久久综合蜜桃| 国产一区二区三区久久| 精品久久一区二区三区| 国产精品久久自在自线观看| 精品久久久久久无码中文字幕一区| 久久精品国产亚洲AV久| 人妻无码久久一区二区三区免费| 国内精品久久久久久99蜜桃| 色欲综合久久躁天天躁蜜桃| 精品久久久久久中文字幕人妻最新|