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 }

 

posted @ 2021-06-06 20:32  yub4by  阅读(80)  评论(0编辑  收藏  举报