字节缓冲流使用 BufferedInputStream 和 BufferedOutputStream这两个流的用法

存储 存储软件
本文主要学习字节缓冲流使用BufferedInputStream和BufferedOutputStream这两个流的用法来实现文本拷贝、字符流、Reader类、Writer类这些的用法。接下来小编带大家一起来学习这些用法!

[[438057]]

大家好,我是Java进阶者。

前言

本文主要学习字节缓冲流使用BufferedInputStream和BufferedOutputStream这两个流的用法来实现文本拷贝、字符流、Reader类、Writer类这些的用法。接下来小编带大家一起来学习这些用法!

一、字节缓冲流

1.在前面我们学习了BufferedInputStream和BufferedOutputStream类,这两个类分别是FilterInputStream类和FilterOutputStream类的子类。它们的构造方法分别接受InputStream和OutStream类型的参数,在读写数据有一个缓冲的功能。

2.使用缓冲流来完成读写数据,接下来通过一个案例使用BufferedInputStream和BufferedOutputStream这两个流的用法来实现文本拷贝。实现例子如下所示:

(1)首先在text文件夹目录下创建一个test11.txt并写入"Hello,world~~~test!"内容。

(2)实现文件的拷贝代码如下所示:

  1. import java.io.*; 
  2. public class P11 { 
  3. public static void main(String[] args) throws Exception { 
  4.         // TODO Auto-generated method stub 
  5.         //创建有缓冲区的输入流和输出流 
  6.         BufferedInputStream in = new BufferedInputStream(new FileInputStream("text/test11")); 
  7.         BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream("text/test12")); 
  8.         int num; 
  9.         //判断是否读到文件的末尾 
  10.         while((num=in.read())!=-1){ 
  11.             bos.write(num); 
  12.         } 
  13.         //关闭流 
  14.         in.close(); 
  15.         bos.close(); 
  16.   } 

运行的结果如下所示:

在上面的代码中,创建了BufferedInputStream和BufferedOutputStream两个缓冲流对象,在这两个流中内部定义一个字节数组,当调用read()方法或write()方法读写数据,先将读写的数据存到字节数组,在把字节数组的数据一次性读写到文件中。

二、字符流

1.我们前面学过InputStream和OutputStream的输入输出操作都是基于字节的,字节流不能操作Unicode字符,我们知道汉字在文件是占2个字节,若使用字节流读取不当会出现乱码现象例如显示一个正方形的框。使用字符流可以避免出现乱码现象。

2.字符流有两个抽象超类分别是Reader和Writer,Reader是字符输入流,使用从某个源设备读取字符,Writer是字符输出流,用于向某个目标设备写入字符。

三、Reader类

1.java.io.Reader是字符输入流的最顶层的父类,这个类定义了以字符为单位读取数据的基本方法,并在子类进行分化和实现。

2.Reader类方法有如下所示:

(1)public int read() throws IOException:读取一个字符。在读取流,如果没有数据就会出现调用受阻的现象,程序会一直等待到有数据读出为止。

(2)public int read(char cbuf[]) throws IOException:读取多个字符到字符数组cbuf。

(3)public int read(char cbuf[],int off,int len) throws IOException:从off开始的位置中读取len个字符存放到字符数组。off参数表示数组偏移量,len参数表示读取数据的长度。

(4)public void mark(int readAheadLimit) throws IOException:在输入流中设置标记。

(5)public boolean markSupporter() throws IOException:测试输入流是否支持mark()方法

(6)public void reset() throws IOException:重置流的当前位置到前面标记的位置。

(7)public void close() throws IOException:表示关闭流。

(8)public long skip(long n) throws IOException:略过流中的数据。若数据不够,跳过仅有的字节,返回跳过的字节数。

(9)public boolean ready():返回输入流是否做好读的准备。

3.Reader类实例代码如下所示:

(1)在text文件夹目录下创建一个test13.txt文件并写入"Hello,World!Java进阶学习交流!"。

(2)代码实现的例子:

  1. public class P12 { 
  2. public static void main(String[] args) throws Exception { 
  3.         // TODO Auto-generated method stub 
  4.         //声明File对象 
  5.         File f=new File("text/test13"); 
  6.         Reader in=new FileReader(f); 
  7.         //所有的数据读到数组c中 
  8.         char c[]=new char[1024]; 
  9.         //读取内容 
  10.         int len=in.read(c); 
  11.         //关闭流 
  12.         in.close(); 
  13.         System.out.println("内容为:"+new String(c,0,len)); 
  14.   } 

运行的结果如下所示:

四、Writer类

1.Writer类是一个写入字符流的抽象类。

2.Writer方法有如下所示:

(1)public void close() throws IOException方法:表示关闭流。

(2)public voir write(int c) throws IOException方法:表示写入单个字符。

(3)public abstract void read(char cbuf[],int off,int len) throws IOException方法:向流中写入一个数组,参数off指定数组的偏移量,len指定读取数据的长度。

(4)public void write(String str) throws IOException方法:写入一个字符串。

五、总结

本文主要介绍了字节缓冲流、字符流、Reader类、Writer类。字节缓冲流是使用BufferedInputStream和BufferedOutputStream这两个流的用法来实现文本拷贝。字符流有两个抽象超类分别是Reader和Writer,Reader是字符输入流,使用从某个源设备读取字符,Writer是字符输出流,用于向某个目标设备写入字符。介绍了Reader类的方法,通过Reader类实例来实现读取文本文件内容,Writer类是一个写入字符流的抽象类。希望大家通过本文的学习,对你有所帮助!

我是Java进阶者,希望大家通过本文的学习,对你有所帮助!欢迎大家加我微信,有问题可以随时帮大家解决噢,交个朋友也好哇~

本文转载自微信公众号「Java进阶学习交流」,可以通过以下二维码关注。转载本文请联系Java进阶学习交流公众号。

 

责任编辑:武晓燕 来源: Java进阶学习交流
相关推荐

2021-12-09 09:30:38

字节流文件缓冲区

2020-02-27 14:05:26

SQLServer数据库

2022-03-07 10:26:25

开源springboot项目

2020-12-10 10:32:33

区块链比特币数字货币

2022-01-26 00:04:01

LinuxTSSLDT

2022-02-23 15:30:28

SpringBoot后端流程

2020-09-21 08:43:55

java

2021-06-30 21:20:21

Python变量闭包

2022-02-21 23:08:50

Kubernetes集群容器

2022-02-09 15:23:41

大数据流计算Spark

2023-09-12 08:19:48

接口Controller线程

2022-06-23 08:01:48

hookSetMap

2023-01-13 16:57:50

SpringBoot配置核心

2021-05-11 16:44:42

Windows工具软件

2017-08-28 14:47:54

NASSAN存储

2021-03-15 09:44:39

Broker源码RocketMQ

2018-03-21 12:13:47

工具数据开发

2010-07-13 10:10:28

WPF

2024-01-11 11:35:46

Python开发

2020-05-14 10:26:27

KafkaSpark数据
点赞
收藏

51CTO技术栈公众号