JavaSE-18.2.1【字符流 = 字节流 + 编码表】
1 package day9.lesson2; 2 3 import java.io.FileInputStream; 4 import java.io.IOException; 5 import java.util.Arrays; 6 7 /* 8 2 字符流 9 10 需求:字节流读取文本文件数据 11 12 一个汉字存储在文本文件时: 13 若为GBK编码,则占用2字节 14 若为UTF-8编码,则占用3字节 15 16 2.1 为什么会出现字符流 17 18 字符流的介绍 19 由于字节流操作中文不是特别的方便,所以Java就提供字符流 20 字符流 = 字节流 + 编码表 21 中文的字节存储方式 22 用字节流复制文本文件时,文本文件也会有中文,但是没有问题, 23 原因是最终底层操作会自动进行字节拼接成中文,如何识别是中文的呢? 24 汉字在存储的时候,无论选择哪种编码存储,第一个字节都是负数 25 26 2.2 编码表 27 28 什么是字符集 29 是一个系统支持的所有字符的集合,包括各国家文字、标点符号、图形符号、数字等 30 计算机要准确的存储和识别各种字符集符号,就需要进行字符编码,一套字符集必然至少有一套字符编码。 31 常见字符集有ASCII字符集、GBXXX字符集、Unicode字符集等 32 33 常见的字符集 34 ASCII字符集: 35 ASCII:是基于拉丁字母的一套电脑编码系统,用于显示现代英语,主要包括控制字符(回车键、退格、 36 换行键等)和可显示字符(英文大小写字符、阿拉伯数字和西文符号) 37 基本的ASCII字符集,使用7位表示一个字符,共128字符。ASCII的扩展字符集使用8位表示一个字符,共 38 256字符,方便支持欧洲常用字符。是一个系统支持的所有字符的集合,包括各国家文字、标点符号、 39 图形符号、数字等 40 GBXXX字符集: 41 GBK:最常用的中文码表。是在GB2312标准基础上的扩展规范,使用了双字节编码方案,共收录了 42 21003个汉字,完全兼容GB2312标准,同时支持繁体汉字以及日韩汉字等 43 Unicode字符集: 44 Unicode又称为统一码/标准万国码,三种编码方案:UTF-6 UTF-16 UTF-32 45 UTF-8编码:可以用来表示Unicode标准中任意字符,它是电子邮件、网页及其他存储或传送文字的应用 46 中,优先采用的编码。互联网工程工作小组(IETF)要求所有互联网协议都必须支持UTF-8编码。它使用 47 一至四个字节为每个字符编码 48 UTF-8编码规则: 49 128个US-ASCII字符,只需一个字节编码 50 拉丁文等字符,需要二个字节编码 51 大部分常用字(含中文),使用三个字节编码 52 其他极少使用的Unicode辅助字符,使用四字节编码 53 */ 54 public class FileInputDemo { 55 public static void main(String[] args) throws IOException { 56 FileInputStream fis = new FileInputStream("stage2\\src\\day9\\lesson2\\a.txt"); 57 int by; 58 while ((by=fis.read()) != -1){ 59 System.out.print((char)by); 60 } 61 //abcä¸å½å æ²¹ 62 //中 国 加 油 63 //ä¸ å½ å æ²¹ 64 fis.close(); 65 66 String s = "abc"; 67 byte[] bys = s.getBytes(); 68 System.out.println(Arrays.toString(bys)); //[97, 98, 99] 69 70 s = "中国加油"; 71 bys = s.getBytes(); 72 System.out.println(Arrays.toString(bys)); //[-28, -72, -83, -27, -101, -67, -27, -118, -96, -26, -78, -71] 73 bys = s.getBytes("UTF-8"); 74 System.out.println(Arrays.toString(bys)); //[-28, -72, -83, -27, -101, -67, -27, -118, -96, -26, -78, -71] 75 bys = s.getBytes("GBK"); 76 System.out.println(Arrays.toString(bys)); //[-42, -48, -71, -6, -68, -45, -45, -51] 77 } 78 }