引出编码表:
我们知道,初学IO的时候使用字节流的read()针对中文操作输出的时候可能出现中文乱码。这是为什么呢?因为myeclipes在默认情况下,使用的编码表示ASCII表,中文是两个字节存储的,ASCII表示一个字节代表一个字符,强行将中文拆分成两个字节进行解析就会找不到对应字符出现?或者找到的字符不可能是中文的。ASCII码讲中文拆分成两个字节。第一个字节的对应位置一定是负数,第二个常见是负数,可能是正数。
编码表:
由现实世界的字符和其对应的数值组成的一张表,用来解析和转换各种字符
常见的编码表
ASCII码表:7位表示一个数据,一个字节表示一个字符。最高位是符号位
‘a' 97 ’A' 65 0 48
ISO-8859-1:拉丁码表 8位表示一个数据
GB2312:中国的简体中文编码表
GBK:中国的简体中文编码表升级
GB18030:GBK的取代版本
BIG-5:繁体中文编码表,俗称“大五码”
Unicode:国际标准码,融合了各种文字
所有文字都用两个字节表示,java语言使用的就是Unicode编码
UTF-8:国际化编码表,升级版
最多能用三个字节表示一个字符。就是能用一个字节表示的字符就使用一个字节表示(兼容ASCII),一个用不了的就用两个,实在还不行就使用三个。
编码问题引发小例子:
比如,中国在gbk编码表示的是 10000 和20000
直接到日本的话,日本编码使用shift-JIS 10000 20000分别代表的是か ら,转换过去就曲解了原来的含义了。