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

            cc

              C++博客 :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              38 隨筆 :: 14 文章 :: 21 評(píng)論 :: 0 Trackbacks
            1. 如何取得一個(gè)既包含單字節(jié)字符又包含雙字節(jié)字符的字符串的字符個(gè)數(shù)?
            可以調(diào)用Microsoft Visual C++的運(yùn)行期庫(kù)包含函數(shù)_mbslen來(lái)操作多字節(jié)(既包括單字節(jié)也包括雙字節(jié))字符串。
            調(diào)用strlen函數(shù),無(wú)法真正了解字符串中究竟有多少字符,它只能告訴你到達(dá)結(jié)尾的0之前有多少個(gè)字節(jié)。

            2. 如何對(duì)DBCS(雙字節(jié)字符集)字符串進(jìn)行操作?
            函數(shù) 描述
            PTSTR CharNext ( LPCTSTR ); 返回字符串中下一個(gè)字符的地址
            PTSTR CharPrev ( LPCTSTR, LPCTSTR ); 返回字符串中上一個(gè)字符的地址
            BOOL IsDBCSLeadByte( BYTE ); 如果該字節(jié)是DBCS字符的第一個(gè)字節(jié),則返回非0值

            3. 為什么要使用Unicode?
            (1) 可以很容易地在不同語(yǔ)言之間進(jìn)行數(shù)據(jù)交換。
            (2) 使你能夠分配支持所有語(yǔ)言的單個(gè)二進(jìn)制.exe文件或DLL文件。
            (3) 提高應(yīng)用程序的運(yùn)行效率。
            Windows 2000是使用Unicode從頭進(jìn)行開(kāi)發(fā)的,如果調(diào)用任何一個(gè)Windows函數(shù)并給它傳遞一個(gè)ANSI字符串,那么系統(tǒng)首先要將字符串轉(zhuǎn)換成Unicode,然后將Unicode字符串傳遞給操作系統(tǒng)。如果希望函數(shù)返回ANSI字符串,系統(tǒng)就會(huì)首先將Unicode字符串轉(zhuǎn)換成ANSI字符串,然后將結(jié)果返回給你的應(yīng)用程序。進(jìn)行這些字符串的轉(zhuǎn)換需要占用系統(tǒng)的時(shí)間和內(nèi)存。通過(guò)從頭開(kāi)始用Unicode來(lái)開(kāi)發(fā)應(yīng)用程序,就能夠使你的應(yīng)用程序更加有效地運(yùn)行。
            Windows CE 本身就是使用Unicode的一種操作系統(tǒng),完全不支持ANSI Windows函數(shù)
            Windows 98 只支持ANSI,只能為ANSI開(kāi)發(fā)應(yīng)用程序。
            Microsoft公司將COM從16位Windows轉(zhuǎn)換成Win32時(shí),公司決定需要字符串的所有COM接口方法都只能接受Unicode字符串。

            4. 如何編寫(xiě)Unicode源代碼?
            Microsoft公司為Unicode設(shè)計(jì)了WindowsAPI,這樣,可以盡量減少代碼的影響。實(shí)際上,可以編寫(xiě)單個(gè)源代碼文件,以便使用或者不使用Unicode來(lái)對(duì)它進(jìn)行編譯。只需要定義兩個(gè)宏(UNICODE和_UNICODE),就可以修改然后重新編譯該源文件。
            _UNICODE宏用于C運(yùn)行期頭文件,而UNICODE宏則用于Windows頭文件。當(dāng)編譯源代碼模塊時(shí),通常必須同時(shí)定義這兩個(gè)宏。

            5. Windows定義的Unicode數(shù)據(jù)類(lèi)型有哪些?
            數(shù)據(jù)類(lèi)型 說(shuō)明
            WCHAR Unicode字符
            PWSTR 指向Unicode字符串的指針
            PCWSTR 指向一個(gè)恒定的Unicode字符串的指針
            對(duì)應(yīng)的ANSI數(shù)據(jù)類(lèi)型為CHAR,LPSTR和LPCSTR。
            ANSI/Unicode通用數(shù)據(jù)類(lèi)型為T(mén)CHAR,PTSTR,LPCTSTR。

            6. 如何對(duì)Unicode進(jìn)行操作?
            字符集 特性 實(shí)例
            ANSI 操作函數(shù)以str開(kāi)頭 strcpy
            Unicode 操作函數(shù)以wcs開(kāi)頭 wcscpy
            MBCS 操作函數(shù)以_mbs開(kāi)頭 _mbscpy
            ANSI/Unicode 操作函數(shù)以_tcs開(kāi)頭 _tcscpy(C運(yùn)行期庫(kù))
            ANSI/Unicode 操作函數(shù)以lstr開(kāi)頭 lstrcpy(Windows函數(shù))
            所有新的和未過(guò)時(shí)的函數(shù)在Windows2000中都同時(shí)擁有ANSI和Unicode兩個(gè)版本。ANSI版本函數(shù)結(jié)尾以A表示;Unicode版本函數(shù)結(jié)尾以W表示。Windows會(huì)如下定義:
            #ifdef UNICODE
            #define CreateWindowEx CreateWindowExW
            #else
            #define CreateWindowEx CreateWindowExA
            #endif // !UNICODE

            7. 如何表示Unicode字符串常量?
            字符集 實(shí)例
            ANSI "string"
            Unicode L"string"
            ANSI/Unicode T("string")或_TEXT("string")if( szError[0] == _TEXT('J') ){}

            8. 為什么應(yīng)當(dāng)盡量使用操作系統(tǒng)函數(shù)?
            這將有助于稍稍提高應(yīng)用程序的運(yùn)行性能,因?yàn)椴僮飨到y(tǒng)字符串函數(shù)常常被大型應(yīng)用程序比如操作系統(tǒng)的外殼進(jìn)程Explorer.exe所使用。由于這些函數(shù)使用得很多,因此,在應(yīng)用程序運(yùn)行時(shí),它們可能已經(jīng)被裝入RAM。
            如:StrCat,StrChr,StrCmp和StrCpy等。

            9. 如何編寫(xiě)符合ANSI和Unicode的應(yīng)用程序?
            (1) 將文本串視為字符數(shù)組,而不是chars數(shù)組或字節(jié)數(shù)組。
            (2) 將通用數(shù)據(jù)類(lèi)型(如TCHAR和PTSTR)用于文本字符和字符串。
            (3) 將顯式數(shù)據(jù)類(lèi)型(如BYTE和PBYTE)用于字節(jié)、字節(jié)指針和數(shù)據(jù)緩存。
            (4) 將TEXT宏用于原義字符和字符串。
            (5) 執(zhí)行全局性替換(例如用PTSTR替換PSTR)。
            (6) 修改字符串運(yùn)算問(wèn)題。例如函數(shù)通常希望在字符中傳遞一個(gè)緩存的大小,而不是字節(jié)。這意味著不應(yīng)該傳遞sizeof(szBuffer),而應(yīng)該傳遞(sizeof(szBuffer)/sizeof(TCHAR)。另外,如果需要為字符串分配一個(gè)內(nèi)存塊,并且擁有該字符串中的字符數(shù)目,那么請(qǐng)記住要按字節(jié)來(lái)分配內(nèi)存。這就是說(shuō),應(yīng)該調(diào)用
            malloc(nCharacters *sizeof(TCHAR)),而不是調(diào)用malloc(nCharacters)。

            10. 如何對(duì)字符串進(jìn)行有選擇的比較?
            通過(guò)調(diào)用CompareString來(lái)實(shí)現(xiàn)。
            標(biāo)志 含義
            NORM_IGNORECASE 忽略字母的大小寫(xiě)
            NORM_IGNOREKANATYPE 不區(qū)分平假名與片假名字符
            NORM_IGNORENONSPACE 忽略無(wú)間隔字符
            NORM_IGNORESYMBOLS 忽略符號(hào)
            NORM_IGNOREWIDTH 不區(qū)分單字節(jié)字符與作為雙字節(jié)字符的同一個(gè)字符
            SORT_STRINGSORT 將標(biāo)點(diǎn)符號(hào)作為普通符號(hào)來(lái)處理

            11. 如何判斷一個(gè)文本文件是ANSI還是Unicode?
            判斷如果文本文件的開(kāi)頭兩個(gè)字節(jié)是0xFF和0xFE,那么就是Unicode,否則是ANSI。

            12. 如何判斷一段字符串是ANSI還是Unicode?
            用IsTextUnicode進(jìn)行判斷。IsTextUnicode使用一系列統(tǒng)計(jì)方法和定性方法,以便猜測(cè)緩存的內(nèi)容。由于這不是一種確切的科學(xué)方法,因此 IsTextUnicode有可能返回不正確的結(jié)果。

            13. 如何在Unicode與ANSI之間轉(zhuǎn)換字符串?
            Windows函數(shù)MultiByteToWideChar用于將多字節(jié)字符串轉(zhuǎn)換成寬字符串;函數(shù)WideCharToMultiByte將寬字符串轉(zhuǎn)換成等價(jià)的多字節(jié)字符串。

            posted on 2010-03-06 00:59 醒目西西 閱讀(303) 評(píng)論(0)  編輯 收藏 引用

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


            久久久91精品国产一区二区三区 | 狠狠色丁香久久婷婷综| 久久精品国产亚洲AV无码麻豆| 久久综合久久自在自线精品自| 少妇高潮惨叫久久久久久| 久久精品国产99国产电影网| 久久无码人妻精品一区二区三区| 热99RE久久精品这里都是精品免费 | 国产精品九九九久久九九| 一级做a爱片久久毛片| 日韩十八禁一区二区久久| 久久精品aⅴ无码中文字字幕不卡| 国产精品成人99久久久久 | 久久精品成人欧美大片| 青青草原综合久久| 无码超乳爆乳中文字幕久久| 国产AⅤ精品一区二区三区久久| 久久香综合精品久久伊人| 久久嫩草影院免费看夜色| 99久久精品日本一区二区免费| 色狠狠久久综合网| 国产精品无码久久综合网| 97超级碰碰碰久久久久| 亚洲va中文字幕无码久久不卡| 久久久久久久久久久免费精品| 久久青青草原国产精品免费| 久久人爽人人爽人人片AV| 波多野结衣久久精品| 久久亚洲中文字幕精品一区| 2021国产成人精品久久| 久久久国产乱子伦精品作者| 久久亚洲国产精品成人AV秋霞| 久久99精品久久久久久野外| 亚洲国产二区三区久久| 精品国产福利久久久| 女人香蕉久久**毛片精品| 精品国产福利久久久| 久久综合久久久| 久久精品国产精品亜洲毛片| 国产激情久久久久影院| 久久久久国产精品麻豆AR影院|