美文网首页
1.字符编码总览

1.字符编码总览

作者: 流年碎影ABC | 来源:发表于2018-03-16 11:29 被阅读0次

先说一个故事:

《圣经•旧约•创世纪》上曾经记载人类为了修建一个能通往天堂的高塔,联合起来。塔一天一天的长高,上帝害怕了,为了阻止人类的计划,上帝想出了一个办法,他让人类说不同的语言。这让人类之间不能沟通,修建通天塔的计划就流产了,通天塔没能修建起来。这就是关于不同语言产生的传说。

然后开始我们今天对字符编码的介绍

第一台电子计算机ENICA于1946年2月14日诞生在美国宾大,自此拉开了计算机时代。计算机是人类发明的产物,那自然要为人类服务,例如做计算,播放音乐等。不管是哪一种都需要跟字符打交道。比如你在网页上要搜索东西,肯定需要输入搜索关键词吧。

我们知道,计算机只能识别0和1,不能直接识别英文,汉字等。聪明的人类想到用一连串01序列来表示,这就是字符编码(当然除了01序列,还有别的形式,例如摩斯密码,这里只讨论01序列,并且以下为方便简称编码。

我们先举几个最早的编码方式来说说,BCD码(全称Binary-Coded Decimal,二进码十进数)是是IBM于1959年在其1401和1620和700系列的计算机中最早使用的六位编码方案。这里可以简单介绍一下:

二进制数的每一个位表示一个计算机位(bit,简称位),按照定义,那么有n位就能表示 2^n 个数。数字0-9一共10个数,那么至少需要4位(2^4 =16>=10)。因此BCD码用了四个位元来储存一个十进制的数码,使二进制之间的转换得以快捷的进行。
例如十进制10,其二进制表示就是1010。但是很明显,缺点就是表示的内容太少。之后,又出现了ASCII码,EBCDIC码等。但是这些码都只能表示很少的字符,例如ASCII(现今最通用的单字节编码系统)最多能表示128种不同的字符。当这些编码方式遇到中文,那肯定就傻眼了,中文那么多,127怎么够。为此,中国的国标字符编码需要占用 2 个字节(最多能表示2^16=65536个字符),中国标准局依次发布了GB2312、GBK、GB18030等。

虽然每个国家或地区的字符编码自行搞定了,就以中国为例,你拿用GBK写的程序,放到香港那里,则会出现乱码,因为香港台湾那里使用的编码方式是BIG-5(俗称大五码)。国内如此,那么各个国家国家间呢?很多国家的编码区间都是重叠的,同一个汉字(比如有一些汉字同时存在于简体、繁体、日语汉字中)有不同的编码,很混乱是不是?但也凑合用了。编码不同导致了很多麻烦,比如一个网页,如果你不知道它是什么编码的,r那么你可能很难确定它显示的是什么,一个字符可能是大陆简体/台湾繁体/日本汉字,但又完全是不同的几个字。
上说所说的情况很混乱是不是?

哪有解决办法吗?答案是有。

为此Unicode编码应运而生,它整合全世界的几乎所有语言文字。1990年开始研发,1994年正式公布。Unicode在统一字符集方面的成功让它在计算机软件的国际化和本地化中有了广泛的应用。它具有一下几个特点:
1.它为每种语言中的每个字符设定了统一并且唯一的二进制编码,以满足跨语言、跨平台进行文本转换、处理的要求。
2.Unicode可以通过不同的字符编码实现。
Unicode标准定义了UTF-8,UTF-16和UTF-32等。其中使用的最普遍的有UTF-8,UTF-16和UCS-2。特别指出,超过90%的网页都使用UTF-8编码。

结束语

好了,说了这么多,不知道读者有没有对字符编码有了一个简单的认识,从这之后,我将简单介绍一下各种不同的编码方式,欢迎你们提出你们的问题和建议。

相关文章

  • 1.字符编码总览

    先说一个故事: 《圣经•旧约•创世纪》上曾经记载人类为了修建一个能通往天堂的高塔,联合起来。塔一天一天的长高,上帝...

  • 字符串

    1.字符的编码 Python中的字符采用的是Unicode编码 1.什么是编码 :数字和字符是一一对应的,其中字符...

  • Python正式课第十三天

    一、文件操作与字符编码 1. 字符编码 编码 将字符转换为对应的二进制序列的过程叫做字符编码(字符->二进制01)...

  • 刨根究底字符编码之九——字符编码方案的演变与字节序

    字符编码方案的演变与字节序 一、字符编码方案的演变 1. 前文已经提及,编号字符集CCS(简称字符集)与字符编码方...

  • day4-字符串

    1.字符编码 python中的字符采用的是Unicode编码 什么是编码将字符与数字一一对应,其中字符对应的数字就...

  • 关于JavaScript编码你应该知道的

    1. 字符集和编码的关系 字符集是字符的集合,编码则是字符集中的字符要如何存储的规则。 如上图,当字符集和编码一一...

  • Day5-总结

    一、Recode 字符串 1.'', "" , '''''' , """""" 2.普通字符,转义字符,编码字符(...

  • Day5 总结

    一.recode 1.'',"", '''''',""""""(表示字符串) 2.普通字符,转义字符,编码字符(\...

  • day3总结

    1.什么是字符串 2.转义字符 3.Unicode编码 1).将Unicode码转换成字符: chr(编码) 2)...

  • Java基础-IO流之字符流

    字符流 = 字节流 + 编码表 一.编码表: 就是由字符和对应的数值组成的一张表 1.常见的编码表: 常见的编码表...

网友评论

      本文标题:1.字符编码总览

      本文链接:https://www.haomeiwen.com/subject/hhpcqftx.html