Unicode

文章發(fā)布地址:https://blog.qiuluo.xin/2019/01/08/unicode/

碼點:表示與編碼表中某個符號對應(yīng)的代碼值。

在Unicode標(biāo)準(zhǔn)中,碼點采用十六進(jìn)制書寫,并加上前綴U+,例如U+0041就是拉丁字母A的碼點Unicode的碼點可以分為17個級別。

第1級別(基本的多語言級別):++U+0000~U+FFFF++,包含常用經(jīng)典Unicode碼。

第2到17級別:++U+10000~U+10FFFF++,包含一些輔助字符。

UTF-16

采用不同長度的及編碼標(biāo)識所有Unicode碼點。

在第1級別:占2字節(jié),每個字符用16位表示,即通常成為代碼單元

輔助字符(2~17級別):占4字節(jié),采用一堆連續(xù)的代碼單元進(jìn)行編碼,這樣構(gòu)成的編碼值落入基本多語言級別中空閑的2048字節(jié)內(nèi)(替代區(qū)域),這樣就可以用有限的編碼數(shù)表示更多的符號。

例:碼點為U+1D546的數(shù)學(xué)符號使用兩個代碼單元U+D835U+DD46表示。

避免注釋中的\u

注意: Unicode轉(zhuǎn)義序列會在解析代碼之前得到處理。

例1"\u0022+\u0022" 并不是一個包含加號\u0022符號的字符串。
實際上,\u0022會在解析前轉(zhuǎn)換為"符號,就會得到""+"",也就是說"\u0022+\u0022"最終是一個空字符串,與""等效。

例2
下面的注釋會產(chǎn)生一個語法錯誤,因為讀程序時\u00A0會替換成一個換行符

// \u00A0 is a newline

例3:下面的注釋也會產(chǎn)生一個語法錯誤,因為\u后面并未跟著4個十六進(jìn)制數(shù),解讀為字符的時候失敗了

// Look inside c:/user
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 轉(zhuǎn)載須注明出處:簡書@Orca_J35 以下內(nèi)容直接翻譯自 Unicode 術(shù)語表:Glossary of Uni...
    import_hello閱讀 3,559評論 0 0
  • 在當(dāng)前這個時代(比如說公元2016年),如果你并不是在維護(hù)歷史遺留的文本處理代碼,沒有在每個地方都使用Unicod...
    縱橫而樂閱讀 2,854評論 3 16
  • 1. ASCII ??我們知道,計算機(jī)內(nèi)部是通過二進(jìn)制數(shù)據(jù)進(jìn)行操作的,所有的信息最終都會轉(zhuǎn)換為一個二進(jìn)制值,二進(jìn)制...
    騎著烏龜去看海閱讀 1,855評論 0 4
  • 字符編碼的問題,每個程序員都會遇到,深入探索其背后的原理和機(jī)制,能讓我們少走很多彎路。 1、歷史簡述 Unicod...
    1angxi閱讀 14,048評論 0 7
  • 說明:本文是我在readthedocs看到的,覺得很不錯所以轉(zhuǎn)載過來,有刪改,原文地址點這里。 實用Unicode...
    aurora閱讀 1,055評論 0 6

友情鏈接更多精彩內(nèi)容