Unicode :寬位元組字元集
1. 如何取得一個既包含單位元組字元又包含雙位元組字元的字串的字元個數?
可以調用Microsoft Visual C++的運行期庫包含函數_mbslen來操作多位元組(既包括單位元組也包括雙位元組)字串。
調用strlen函數,無法真正瞭解字串中究竟有多少字元,它只能告訴你到達結尾的0之前有多少個位元組。
2. 如何對DBCS(雙位元組字元集)字串進行操作?
函數 描述
PTSTR CharNext ( LPCTSTR ); 返回字串中下一個字元的地址
PTSTR CharPrev ( LPCTSTR, LPCTSTR ); 返回字串中上一個字元的地址
BOOL IsDBCSLeadByte( BYTE ); 如果該位元組是DBCS字元的第一個位元組,則返回非0值
3. 為什麼要使用Unicode?
(1) 可以很容易地在不同語言之間進行資料交換。
(2) 使你能夠分配支援所有語言的單個二進位.exe檔案或DLL檔案。
(3) 提高應用程式的運行效率。
Windows 2000是使用Unicode從頭進行開發的,如果調用任何一個Windows函數並給它傳遞一個ANSI字串,那麼系統首先要將字串轉換成Unicode,然後將Unicode字串傳遞給作業系統。如果希望函數返回ANSI字串,系統就會首先將Unicode字串轉換成ANSI字串,然後將結果返回給你的應用程式。進行這些字串的轉換需要佔用系統的時間和記憶體。通過從頭開始用Unicode來開發應用程式,就能夠使你的應用程式更加有效地運行。
Windows CE 本身就是使用Unicode的一種作業系統,完全不支援ANSI Windows函數
Windows 98 只支援ANSI,只能為ANSI開發應用程式。
Microsoft公司將COM從16位Windows轉換成Win32時,公司決定需要字串的所有COM介面方法都只能接受Unicode字串。
4. 如何編寫Unicode原始碼?
Microsoft公司為Unicode設計了WindowsAPI,這樣,可以盡量減少代碼的影響。實際上,可以編寫單個原始碼檔案,以便使用或者不使用Unicode來對它進行編譯。只需要定義兩個宏(UNICODE和_UNICODE),就可以修改然後重新編譯該源檔案。
_UNICODE宏用於C運行期標頭檔,而UNICODE宏則用於Windows標頭檔。當編譯原始碼模組時,通常必須同時定義這兩個宏。
5. Windows定義的Unicode資料類型有哪些?
資料類型 說明
WCHAR Unicode字元
PWSTR 指向Unicode字串的指標
PCWSTR 指向一個恒定的Unicode字串的指標
對應的ANSI資料類型為CHAR,LPSTR和LPCSTR。
ANSI/Unicode通用資料類型為TCHAR,PTSTR,LPCTSTR。
6. 如何對Unicode進行操作?
字元集 特性 執行個體
ANSI 操作函數以str開頭 strcpy
Unicode 操作函數以wcs開頭 wcscpy
MBCS 操作函數以_mbs開頭 _mbscpy
ANSI/Unicode 操作函數以_tcs開頭 _tcscpy(C運行期庫)
ANSI/Unicode 操作函數以lstr開頭 lstrcpy(Windows函數)
所有新的和未過時的函數在Windows2000中都同時擁有ANSI和Unicode兩個版本。ANSI版本函數結尾以A表示;Unicode版本函數結尾以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. 為什麼應當盡量使用作業系統函數?
這將有助於稍稍提高應用程式的運行效能,因為作業系統字串函數常常被大型應用程式比如作業系統的外殼進程Explorer.exe所使用。由於這些函數使用得很多,因此,在應用程式運行時,它們可能已經被裝入RAM。
如:StrCat,StrChr,StrCmp和StrCpy等。
9. 如何編寫符合ANSI和Unicode的應用程式?
(1) 將文本串視為字元數組,而不是chars數組或位元組數組。
(2) 將通用資料類型(如TCHAR和PTSTR)用於文本字元和字串。
(3) 將顯式資料類型(如BYTE和PBYTE)用於位元組、位元組指標和資料緩衝。
(4) 將TEXT宏用於原義字元和字串。
(5) 執行全域性替換(例如用PTSTR替換PSTR)。
(6) 修改字串運算問題。例如函數通常希望在字元中傳遞一個緩衝的大小,而不是位元組。這意味著不應該傳遞sizeof(szBuffer),而應該傳遞(sizeof(szBuffer)/sizeof(TCHAR)。另外,如果需要為字串分配一個記憶體塊,並且擁有該字串中的字元數目,那麼請記住要按位元組來分配記憶體。這就是說,應該調用malloc(nCharacters *sizeof(TCHAR)),而不是調用malloc(nCharacters)。
10. 如何對字串進行有選擇的比較?
通過調用CompareString來實現。
標誌 含義
NORM_IGNORECASE 忽略字母的大小寫
NORM_IGNOREKANATYPE 不區分平假名與片假名字元
NORM_IGNORENONSPACE 忽略無佔空間字元
NORM_IGNORESYMBOLS 忽略符號
NORM_IGNOREWIDTH 不區分單位元組字元與作為雙位元組字元的同一個字元
SORT_STRINGSORT 將標點符號作為普通符號來處理
11. 如何判斷一個文字檔是ANSI還是Unicode?
判斷如果文字檔的開頭兩個位元組是0xFF和0xFE,那麼就是Unicode,否則是ANSI。
12. 如何判斷一段字串是ANSI還是Unicode?
用IsTextUnicode進行判斷。IsTextUnicode使用一系列統計方法和定性方法,以便猜測緩衝的內容。由於這不是一種確切的科學方法,因此 IsTextUnicode有可能返回不正確的結果。
13. 如何在Unicode與ANSI之間轉換字串?
Windows函數MultiByteToWideChar用於將多位元組字串轉換成寬字元串;函數WideCharToMultiByte將寬字元串轉換成等價的多位元組字串。
本文來自CSDN部落格,轉載請標明出處:http://blog.csdn.net/syf442/archive/2009/09/10/4538801.aspx