Unicode编码

简介: 本篇文章介绍 Unicode 编码。

介绍 Unicode 编码

Unicode 的全称是 Unicode 标准(The Unicode Standard)。

Unicode 又被称为:统一码、万国码、统一字元码、统一字符编码。

Unicode 至今仍在不断增修,每个新版本都加入更多新的字符。目前 Unicode 最新的版本为 2021 年 9 月 14 日公布的 14.0.0,已经收录超过 14 万个字符。


技术是为了解决问题而生的,Unicode 编码解决了什么问题,它的作用是什么呢?

  • Unicode 为解决传统字符编码方案的局限而产生。传统字符编码方案的局限是:它们只能表示一种语言的字符,而不能表示多种语言的字符,这就导致了不同语言的字符无法混合出现在一个文本中。
  • Unicode 编码了世界上大部分的文字系统,使得电脑能以通用的编码方案来处理多种语言混合出现的文本。

Unicode 的编码和实现

大概来说,Unicode 编码系统可分为 “编码方式” 和 “实现方式” 两个层次。

十大设计原则

Wayback Machine (archive.org)

《The Unicode Standard Version 6.2 – Core Specification》文档给出了 Unicode 的十大设计原则:

  • Universality:提供单一、综合的字符集,编码一切现代与大部分历史文献的字符。
  • Efficiency:易于处理与分析。
  • Characters, not glyphs:字符,而不是字形。
  • Semantics:字符要有良好定义的语义。
  • Plain text:仅限于文本字符。
  • Logical order:默认内存表示是其逻辑序。
  • Unification:把不同语言的同一书写系统(scripts)中相同字符统一起来。
  • Dynamic composition:附加符号可以动态组合。
  • Stability:已分配的字符与语义不再改变。
  • Convertibility:Unicode 与其他著名字符集可以精确转换。

Unicode 的编码方式

Unicode 为每一个有效字符定义一个唯一的代码点(code point,即一个整数)。通常使用十六进制表示法来表示 Unicode 代码点,并使用 "U+" 作为前缀。比如,“字母 a” 的 Unicode 代码点是 U+0061。

Unicode 的实现方式

Unicode 的实现方式不同于编码方式。一个字符的 Unicode 编码结果确定,但是在实际传输过程中,由于不同系统平台的设计不一定一致,以及出于节省空间的目的,对 Unicode 编码的实现方式有所不同。

系统平台指的是:在电脑里让软件运行的系统环境,包括硬件环境 和 软件环境。

Mac 和 Windows 对字节序的理解不一致。这时同一字节序列可能会被 Mac 和 Win 解码为不同内容,比如某字符的代码点为 4E59,按两个字节拆分为 4E 和 59:

  • 在 Mac 上是从低字节开始读取,那么 Mac 会认为此 4E59 编码为 594E,找到的字符为 “奎”;
  • 在 Windows 上是从高字节开始读取,那么 Mac 会认为此 4E59 编码为 4E59,找到的字符为 “乙”。

字节序指的是:数据在存储和传输时的字节顺序,也就是字节的排列顺序。


Unicode 的实现方式称为 Unicode 转换格式(Unicode Transformation Format,简称为 UTF)。Unicode 相当于规定了字符对应的代码点,这个代码点需要转换为字节序列的形式去存储、传输。

Unicode 常见的实现方式有:UTF-8、UTF-16小端序(LE)、UTF-16大端序(BE)、UTF-32

在这几种实现方式的名称中,“-” 右边的整数的含义是:以多少个比特位作为一个编码单元。以 UTF-8 为例,它会以 8 个比特(一个字节)作为一个编码单元。

介绍 Unicode 字符平面映射

Unicode 的编码空间从 U+0000 到 U+10FFFF,共有 1,112,064 个代码点(code point)可用来映射字符。Unicode 字符 和 代码点是一对一映射的。

Unicode 将编码空间分成 17 个平面,以 0 到 16 编号。每个平面包含 65536(2^16^)个代码点。

  • 第 0 平面被称为 “基本多文种平面”;
  • 第 1 - 16 平面被称为 “辅助平面”。

第 0 平面(或者说基本多文种平面)中的码点,都可以用一个 UTF-16 单位来编码,或者以 UTF-8 来编码的话,会使用一、二 或 三 个字节。而第 1 到 16 平面(或称辅助平面)中的码点,UTF-16 会以代理对的方式来使用,而 UTF-8 则会编码成 4 个字节。

平面 始末字符值 中文名称
0号平面 U+0000 - U+FFFF 基本多文种平面
1号平面 U+10000 - U+1FFFF 多文种补充平面
2号平面 U+20000 - U+2FFFF 表意文字补充平面
3号平面 U+30000 - U+3FFFF 表意文字第三平面
4号平面 至 13号平面 U+40000 - U+DFFFF (尚未使用)
14号平面 U+E0000 - U+EFFFF 特别用途补充平面
15号平面 U+F0000 - U+FFFFF 保留作为私人使用区(A区)
16号平面 U+100000 - U+10FFFF 保留作为私人使用区(B区)

参考资料

Unicode - 维基百科,自由的百科全书 (wikipedia.org)

Unicode字符平面映射 - 维基百科,自由的百科全书 (wikipedia.org)

相关文章
|
7月前
|
存储 自然语言处理 C++
Unicode编码
Unicode编码
266 4
|
7月前
|
网络协议
ASCII编码
ASCII编码
195 1
|
JavaScript 前端开发 Java
Unicode转义(\uXXXX)的编码和解码
  在涉及Web前端开发时, 有时会遇到\uXXXX格式表示的字符, 其中XXXX是16进制数字的字符串表示形式, 在js中这个叫Unicode转义字符, 和\n \r同属于转义字符. 在其他语言中也有类似的, 可能还有其它变形的格式.
2623 0
|
存储 Windows
“浅入深处“编码历史,字符串编码(ASCII, GBK, ANSI, Unicode, UTF-8编码),为什么记事本默认ANSI编码,Unicode和UTF8有什么区别
“浅入深处“编码历史,字符串编码(ASCII, GBK, ANSI, Unicode, UTF-8编码),为什么记事本默认ANSI编码,Unicode和UTF8有什么区别
152 0
|
iOS开发
Unicode 与 UTF-8 编码的转换
Unicode 与 UTF-8 编码的转换
Unicode 与 UTF-8 编码的转换
NSURL汉字UTF8编码
NSURL汉字UTF8编码
113 0
|
Web App开发 存储 Windows
字符编码知识:Unicode、UTF-8、ASCII、GB2312等编码之间是如何转换的?
转自:  http://apps.hi.baidu.com/share/detail/17798660 字符编码是计算机技术的基石,想要熟练使用计算机,就必须懂得字符编码的知识。不注意的人可能对这个不在意,但这些名词有时候实在让人迷惑,对想学习计算机知识的人来说,搞懂它也十分重要,我也是在学习中慢慢了解了一些这方面的知识。
1915 0
|
存储 算法 Java
【字符编码】字符编码 && Base64编码算法
  在前面的解决乱码的一文中,只找到了解决办法,但是没有为什么,说白了,就是对编码还是不是太熟悉,编码问题是一个很简单的问题,计算机从业人员应该也必须弄清楚,基于编码的应用有Base64加密算法,然后,这个问题一直放着,想找个机会解决。于是乎,终于逮到机会,开始下手。
248 0
【字符编码】字符编码 && Base64编码算法
Unicode转中文,Unicode编码转换,ASCII转Unicode,Unicode转ASCII
DEMO https://oktools.net/unicode Unicode转中文 function decodeUnicode() { let input = area_input.