前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >字节缓冲流使用BufferedInputStream和BufferedOutputStream这两个流的用法

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

作者头像
Java进阶者
发布2021-12-02 13:11:07
5150
发布2021-12-02 13:11:07
举报

前言

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

一、字节缓冲流

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

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

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

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

代码语言:javascript
复制
import java.io.*;
public class P11 {
public static void main(String[] args) throws Exception {
        // TODO Auto-generated method stub
        //创建有缓冲区的输入流和输出流
        BufferedInputStream in = new BufferedInputStream(new FileInputStream("text/test11"));
        BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream("text/test12"));
        int num;
        //判断是否读到文件的末尾
        while((num=in.read())!=-1){
            bos.write(num);
        }
        //关闭流
        in.close();
        bos.close();
  }
}

运行的结果如下所示:

在上面的代码中,创建了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)代码实现的例子:

代码语言:javascript
复制
public class P12 {
public static void main(String[] args) throws Exception {
        // TODO Auto-generated method stub
        //声明File对象
        File f=new File("text/test13");
        Reader in=new FileReader(f);
        //所有的数据读到数组c中
        char c[]=new char[1024];
        //读取内容
        int len=in.read(c);
        //关闭流
        in.close();
        System.out.println("内容为:"+new String(c,0,len));
  }
}

运行的结果如下所示:

四、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类是一个写入字符流的抽象类。希望大家通过本文的学习,对你有所帮助!

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2021-12-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Java进阶学习交流 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 一、字节缓冲流
  • 二、字符流
  • 三、Reader类
  • 四、Writer类
  • 五、总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档