Java基础补充.Day14

字节缓冲流

Java基础补充.Day14

减少底层调用,提高效率

Java基础补充.Day14

Java基础补充.Day14

Java基础补充.Day14

Java基础补充.Day14

Java基础补充.Day14

用缓冲区写数据

Java基础补充.Day14

看源码,调用缓冲区构造器的时候创建了一个大小为8192字节的数组存数据作为缓冲

Java基础补充.Day14

缓冲区读数据

Java基础补充.Day14

复制avi视频

使用System.currentTimeMillis();计算时长

Java基础补充.Day14

Java基础补充.Day14

字符流

为什么要用字符流?

GBK编码占用2个字节,UTF-8编码占用3个字节

Java基础补充.Day14

这种拿到一个字节就读了就出问题了

字节流复制中文不出问题的原因:

因为中文无论是按照GBK--2字节还是UTF-8--3字节编码,第一个字节都会是负数,这样系统按照编码方式转译

Java基础补充.Day14

字符流的底层还是字节流


编码表

Java基础补充.Day14

Java基础补充.Day14

Java基础补充.Day14

Java基础补充.Day14

Java基础补充.Day14

Java基础补充.Day14

Java基础补充.Day14

Java基础补充.Day14

编码解码问题

Java基础补充.Day14

Java基础补充.Day14

字符流的编码解码问题

Java基础补充.Day14

InputStreamReader类

Java基础补充.Day14

Java基础补充.Day14

同理OutputStreamWriter类

Java基础补充.Day14

编码构造器

Java基础补充.Day14

Java基础补充.Day14

如果后面是GBK,打开文件就会出现乱码,因为文件的编码方式是UTF-8,而指定了GBK的编码方式,所以出现乱码

但如果用GBk的方式去解码就能顺利读出来

  • 把用GBK编码的文件按默认UTF-8解码

Java基础补充.Day14

  • 把用GBK编码的文件按GBK解码

Java基础补充.Day14

字符流写数据

Java基础补充.Day14

Java基础补充.Day14

直接这么写写不进去文件,因为字符流通过字节流去写,数据现在存在缓冲区里,需要刷新缓冲,用flush()方法

Java基础补充.Day14

但如果不写刷新在后面写关闭也行,因为close方法是先刷新缓冲再释放资源,但close方法后面不能继续写数据Java基础补充.Day14

Java基础补充.Day14

字符流读数据

Java基础补充.Day14

 

上一篇:day14 异常


下一篇:java-day14