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

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

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

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

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

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

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

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

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

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

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

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

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

            posted on 2010-03-06 00:59 醒目西西 閱讀(302) 評論(0)  編輯 收藏 引用
            久久亚洲精品成人无码网站| 久久久亚洲AV波多野结衣| 一本大道加勒比久久综合| 无码任你躁久久久久久| 精品久久人妻av中文字幕| 一级女性全黄久久生活片免费 | 久久久久久毛片免费看| 久久亚洲精品国产精品婷婷| 国内精品九九久久久精品| 久久香蕉国产线看观看99| 性做久久久久久免费观看| 国产精品久久久久久影院| 久久国产精品免费| 国产午夜精品久久久久免费视| 国产精品99久久久精品无码 | 久久美女网站免费| 久久久一本精品99久久精品88| 久久久无码精品亚洲日韩软件| 亚洲国产成人久久精品影视 | 香蕉久久久久久狠狠色| 久久精品麻豆日日躁夜夜躁| 久久久久久无码Av成人影院| 少妇久久久久久被弄高潮| 久久精品aⅴ无码中文字字幕重口| 亚洲AV无码一区东京热久久| 99国产欧美精品久久久蜜芽| a级毛片无码兔费真人久久| 国产叼嘿久久精品久久| 久久婷婷午色综合夜啪| 久久亚洲精品中文字幕| 青青草国产精品久久| 亚洲国产天堂久久综合| 无码久久精品国产亚洲Av影片| 久久综合久久综合久久综合| 久久精品人妻一区二区三区| 久久99国产精品久久99小说| 国产精品久久久久久吹潮| 久久精品免费网站网| 人妻无码αv中文字幕久久| 99久久精品国产一区二区三区 | 久久精品国产91久久麻豆自制|