字符集 下篇

2021-10-22 08:44:36 字數 1259 閱讀 5220

字串前面加l表示該字串是

字串。

_t是乙個巨集,如果專案使用了unicode字符集(定義了unicode巨集),則自動在字串前面加上l,否則字串不變。因此,visual

c++裡邊定義字串的時候,用_t來保證相容性。vc支援ascii和unicode兩種字元型別,用_t可以保證從ascii編碼型別轉換到unicode編碼型別的時候,程式不需要修改。

以下是別人的總結:

一、在字串前加乙個l作用:

如 l"我的字串" 表示將ansi字串轉換成unicode的字串,就是每個字元占用兩個位元組。

strlen(「asd」) = 3;

strlen(l"asd") = 6;

二、_t巨集可以把乙個引號引起來的字串,根據你的環境設定,使得編譯器會根據編譯目標環境選擇合適的(unicode還是ansi)字元處理方式

如果你定義了unicode,那麼_t巨集會把字串前面加乙個l。這時 _t(「abcd」) 相當於 l"abcd" ,這是寬字串。

如果沒有定義,那麼_t巨集不會在字串前面加那個l,_t(「abcd」) 就等價於 「abcd」

三、text,_text 和_t 一樣的

如下面三語句:

tchar szstr1 = text(「str1」);

char szstr2 = 「str2」;

wchar szstr3 = l(「str3」);

那麼第一句話在定義了unicode時會解釋為第三句話,沒有定義時就等於第二句話。

但二句話無論是否定義了unicode都是生成乙個ansi字串,而第三句話總是生成unicode字串。

為了程式的可移植性,建議都用第一種表示方法。但在某些情況下,某個字元必須為ansi或unicode,那就用後兩種方法。

別人的總結2:

你要確定你需要的字串是寬字元還是窄字元。_t("")是說如果你定義了unicode

那麼就是l"",沒有定義就是"";以下情況用_t()比較好,其他情況最好別用:

1,用thcar,lptstr,lpctstr等tchar資料型別的時候

2,用_tprintf之類的_t版本執行時函式時候

3,像下面這樣有w和a版本的api,呼叫createfile的時候

#ifdef

unicode

#define createfile createfilew

#else

#define createfile

createfilea

#endif // !unicode

mysql api 字符集 MySQL字符集

mysql字符集包括字符集 character 和 collation 兩個概念。字符集是用來定義mysql儲存字串的規則,校對規則則是定義了比較字串的方式。字串和校對規則是一對多的 關係。使用命令 show collation like gbk 可檢視相關的校對規則 使用 show charact...

Unicode字符集和多字符集

由於各國語言的加入,ascii已經不能滿足資訊交流的需要,因此,為了能夠表示其它國家的文字,各國在ascii的基礎上制定了自己的字符集,它們正式的名稱應該是mbcs multi byte chactacter system,即多位元組字元系統 型別說明 unicode ansi 通用型別 字元wch...

mysql 集群字符集 Mysql 字符集

字符集與字元比較 字符集字符集是某種字元的集合,比如最常見的ascii碼,由127個字元組成,只需要乙個位元組就能表示 我們常說的字符集還是gbk iso utf8 mysql 我們使用得最多的字符集就是gbk 和 utf8了 他們都是變長字符集,如果字元在ascii範圍內就使用乙個位元組表示,其他...