JavaSE18-字节缓冲流&字符流

时间:2021-11-17 11:19:26

1.字节缓冲流

1.1 字节缓冲流构造方法

字节缓冲流介绍

  BufferOutputStream:该类实现缓冲输出流。 通过设置这样的输出流,应用程序可以向底层输出流写 入字节,而不必为写入的每个字节导致底层系统的调用

  BufferedInputStream:创建BufferedInputStream将创建一个内部缓冲区数组。 当从流中读取或跳过 字节时,内部缓冲区将根据需要从所包含的输入流中重新填充,一次很多字节

构造方法

方法名 说明
BufferedOutputStream(OutputStream out) 创建字节缓冲输出流对象
BufferedInputStream(InputStream in) 创建字节缓冲输入流对象

1.2 字节流复制视频

实现步骤

  根据数据源创建字节输入流对象

  根据目的地创建字节输出流对象

  读写数据,复制视频

  释放资源

 1 import java.io.*;
2
3 public class BisCopyVideo {
4 public static void main(String[] args) throws IOException {
5 File srcFiles = new File("F:\\1_in.mp4");
6 File destFile = new File("E:\\out.mp4");
7
8 BufferedInputStream bis = new BufferedInputStream(new FileInputStream(srcFiles));
9 BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream(destFile));
10
11 byte[] buffer = new byte[4096];
12 int len;
13 while ((len = bis.read(buffer)) != -1){
14 bos.write(buffer,0,len);
15 }
16
17 bis.close();
18 bos.close();
19 }
20 }

2.字符流

2.1 为什么会出现字符流

字符流的介绍

  由于字节流操作中文不是特别的方便,所以Java就提供字符流

  字符流 = 字节流 + 编码表

中文的字节存储方式

  用字节流复制文本文件时,文本文件也会有中文,但是没有问题,原因是最终底层操作会自动进行字节拼接成中文,如何识别是中文的呢?

  汉字在存储的时候,无论选择哪种编码存储,第一个字节都是负数

2.2 编码表

什么是字符集

  是一个系统支持的所有字符的集合,包括各国家文字、标点符号、图形符号、数字等

  计算机要准确的存储和识别各种字符集符号,就需要进行字符编码,一套字符集必然至少有一套字符编码。 常见字符集有ASCII字符集、GBXXX字符集、Unicode字符集等

常见的字符集

  ASCII字符集:

    ASCII:是基于拉丁字母的一套电脑编码系统,用于显示现代英语,主要包括控制字符(回车键、退格、 换行键等)和可显示字符(英文大小写字符、阿拉伯数字和西文符号)

    基本的ASCII字符集,使用7位表示一个字符,共128字符。ASCII的扩展字符集使用8位表示一个字符,共 256字符,方便支持欧洲常用字符。是一个系统支持的所有字符的集合,包括各国家文字、标点符号、 图形符号、数字等

  GBXXX字符集:

    GBK:最常用的中文码表。是在GB2312标准基础上的扩展规范,使用了双字节编码方案,共收录了 21003个汉字,完全兼容GB2312标准,同时支持繁体汉字以及日韩汉字等

  Unicode字符集:

    UTF-8编码:可以用来表示Unicode标准中任意字符,它是电子邮件、网页及其他存储或传送文字的应用 中,优先采用的编码。互联网工程工作小组(IETF)要求所有互联网协议都必须支持UTF-8编码。它使用一至四个字节为每个字符编码

  编码规则:

  128个US-ASCII字符,只需一个字节编码

  拉丁文等字符,需要二个字节编码

  大部分常用字(含中文),使用三个字节编码

  其他极少使用的Unicode辅助字符,使用四字节编码

2.3 字符串中的编码解码问题

方法名 说明
byte[] getBytes() 使用平台的默认字符集将该 String编码为一系列字节
byte[] getBytes(String charsetName) 使用指定的字符集将该 String编码为一系列字节
String(byte[] bytes) 使用平台的默认字符集解码指定的字节数组来创建字符串
String(byte[] bytes, String charsetName) 通过指定的字符集解码指定的字节数组来创建字符串

2.4 字符流中的编码解码问题

字符流中和编码解码问题相关的两个类

  InputStreamReader:是从字节流到字符流的桥梁

    它读取字节,并使用指定的编码将其解码为字符

    它使用的字符集可以由名称指定,也可以被明确指定,或者可以接受平台的默认字符集

  OutputStreamWriter:是从字符流到字节流的桥梁

    是从字符流到字节流的桥梁,使用指定的编码将写入的字符编码为字节

    它使用的字符集可以由名称指定,也可以被明确指定,或者可以接受平台的默认字符集

构造方法

方法名 说明
InputStreamReader(InputStream in) 使用默认字符编码创建InputStreamReader对 象
InputStreamReader(InputStream in,String chatset) 使用指定的字符编码创建InputStreamReader 对象
OutputStreamWriter(OutputStream out) 使用默认字符编码创建OutputStreamWriter对 象
OutputStreamWriter(OutputStream out,String charset) 使用指定的字符编码创建OutputStreamWriter 对象

2.5 字符流写数据的5种方式

方法名 说明
void write(int c) 写一个字符
void write(char[] cbuf) 写入一个字符数组
void write(char[] cbuf, int off, int len) 写入字符数组的一部分
void write(String str) 写一个字符串
void write(String str, int off, int len) 写一个字符串的一部分

刷新和关闭

方法名 说明
flush() 刷新流,之后还可以继续写数据
close() 关闭流,释放资源,但是在关闭之前会先刷新流。一旦关闭,就不能再写数据

2.6 字符流读数据的2种方式

方法名 说明
int read() 一次读一个字符数据
int read(char[] cbuf) 一次读一个字符数组数据

2.7 字符缓冲流

字符缓冲流介绍

  BufferedWriter:将文本写入字符输出流,缓冲字符,以提供单个字符,数组和字符串的高效写入,可 以指定缓冲区大小,或者可以接受默认大小。默认值足够大,可用于大多数用途

  BufferedReader:从字符输入流读取文本,缓冲字符,以提供字符,数组和行的高效读取,可以指定缓 冲区大小,或者可以使用默认大小。 默认值足够大,可用于大多数用途

方法名 说明
BufferedWriter(Writer out) 创建字符缓冲输出流对象
BufferedReader(Reader in) 创建字符缓冲输入流对象

2.8 字符缓冲流特有功能

BufferedWriter:

方法名 说明
void newLine() 写一行行分隔符,行分隔符字符串由系统属性定义

BufferedReader:

方法名 说明
String readLine() 读一行文字。 结果包含行的内容的字符串,不包括任何行终止字符如果流的结尾已经 到达,则为null