字节缓冲流和字符流

162 阅读3分钟

#一.字节缓冲流介绍 1.定义

  • lBufferOutputStream:该类实现缓冲输出流。 通过设置这样的输出流,应用程序可以向底层输出流写入字节,而不必为写入的每个字节导致底层系统的调用
  • lBufferedInputStream:创建BufferedInputStream将创建一个内部缓冲区数组。 当从流中读取或跳过字节时,内部缓冲区将根据需要从所包含的输入流中重新填充,一次很多字节

2.构造方法

image.png

3.字符流

为中文而设计:字符流 = 字节流 + 编码表

中文字节的存储方式

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

4.编码表的理解

相间的字符集

ASCII字符集:

  • lASCII:
  • 是基于拉丁字母的一套电脑编码系统,用于显示现代英语,主要包括控制字符(回车键、退格、 换行键等)和可显示字符(英文大小写字符、阿拉伯数字和西文符号) 基本的ASCII字符集,使用7位表示一个字符,共128字符。ASCII的扩展字符集使用8位表示一个字符,共 256字符,方便支持欧洲常用字符。是一个系统支持的所有字符的集合,包括各国家文字、标点符号、 图形符号、数字等
  • GBXXX字符集:

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

  • Unicode字符集:

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

  • 128个US-ASCII字符,只需一个字节编码 拉丁文等字符,需要二个字节编码 大部分常用字(含中文),使用三个字节编码 其他极少使用的Unicode辅助字符,使用四字节编码

5.相关方法

image.png

63.字符流写数据的五种应用

image.png

7.字符流读数据的两种方式

image.png

二.字节缓冲流

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

1.特有功能

image.png

小结: 字节流可以复制任意文件,有四种方式一般采用字节缓冲流一次读写一个字节数组的方式。 字符流只能复制文本数据,有五种方式,一般采用字符缓冲流的特有功能。