Java中BufferedReader与BufferedWriter类的使用示例

 更新时间:2016年06月30日 08:58:44   作者:skywangkw  
BufferedReader与BufferedWriter分别继承于Reader和Writer类,分别为字符的读取和写入添加缓冲功能,这里我们就来看一下Java中BufferedReader与BufferedWriter类的使用示例:

BufferedReader
BufferedReader 是缓冲字符输入流。它继承于Reader。
BufferedReader 的作用是为其他字符输入流添加一些缓冲功能。
创建BufferReader时,我们会通过它的构造函数指定某个Reader为参数。BufferReader会将该Reader中的数据分批读取,每次读取一部分到缓冲中;操作完缓冲中的这部分数据之后,再从Reader中读取下一部分的数据。
为什么需要缓冲呢?原因很简单,效率问题!缓冲中的数据实际上是保存在内存中,而原始数据可能是保存在硬盘或NandFlash中;而我们知道,从内存中读取数据的速度比从硬盘读取数据的速度至少快10倍以上。
那干嘛不干脆一次性将全部数据都读取到缓冲中呢?第一,读取全部的数据所需要的时间可能会很长。第二,内存价格很贵,容量不想硬盘那么大。

示例:

import java.io.BufferedReader;
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.InputStream;
import java.io.FileReader;
import java.io.IOException;
import java.io.FileNotFoundException;
import java.lang.SecurityException;

public class BufferedReaderTest {

  private static final int LEN = 5;

  public static void main(String[] args) {
    testBufferedReader() ;
  }

  /**
   * BufferedReader的API测试函数
   */
  private static void testBufferedReader() {

    // 创建BufferedReader字符流,内容是ArrayLetters数组
    try {
      File file = new File("bufferedreader.txt");
      BufferedReader in =
         new BufferedReader(
           new FileReader(file));

      // 从字符流中读取5个字符。“abcde”
      for (int i=0; i<LEN; i++) {
        // 若能继续读取下一个字符,则读取下一个字符
        if (in.ready()) {
          // 读取“字符流的下一个字符”
          int tmp = in.read();
          System.out.printf("%d : %c\n", i, tmp);
        }
      }

      // 若“该字符流”不支持标记功能,则直接退出
      if (!in.markSupported()) {
        System.out.println("make not supported!");
        return ;
      }

      // 标记“当前索引位置”,即标记第6个位置的元素--“f”
      // 1024对应marklimit
      in.mark(1024);

      // 跳过22个字符。
      in.skip(22);

      // 读取5个字符
      char[] buf = new char[LEN];
      in.read(buf, 0, LEN);
      System.out.printf("buf=%s\n", String.valueOf(buf));
      // 读取该行剩余的数据
      System.out.printf("readLine=%s\n", in.readLine());

      // 重置“输入流的索引”为mark()所标记的位置,即重置到“f”处。
      in.reset();
      // 从“重置后的字符流”中读取5个字符到buf中。即读取“fghij”
      in.read(buf, 0, LEN);
      System.out.printf("buf=%s\n", String.valueOf(buf));

      in.close();
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    } catch (SecurityException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }
}

程序中读取的bufferedreader.txt的内容如下:

abcdefghijklmnopqrstuvwxyz
0123456789
ABCDEFGHIJKLMNOPQRSTUVWXYZ

运行结果:

0 : a
1 : b
2 : c
3 : d
4 : e
buf=01234
readLine=56789
buf=fghij

BufferedWriter
BufferedWriter 是缓冲字符输出流。它继承于Writer。
BufferedWriter 的作用是为其他字符输出流添加一些缓冲功能。
BufferedWriter通过字符数组来缓冲数据,当缓冲区满或者用户调用flush()函数时,它就会将缓冲区的数据写入到输出流中。
示例:

import java.io.BufferedWriter;
import java.io.File;
import java.io.OutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.FileNotFoundException;
import java.lang.SecurityException;
import java.util.Scanner;

public class BufferedWriterTest {

  private static final int LEN = 5;
  // 对应英文字母“abcdefghijklmnopqrstuvwxyz”
  //private static final char[] ArrayLetters = "abcdefghijklmnopqrstuvwxyz";
  private static final char[] ArrayLetters = new char[] {'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};

  public static void main(String[] args) {
    testBufferedWriter() ;
  }

  /**
   * BufferedWriter的API测试函数
   */
  private static void testBufferedWriter() {

    // 创建“文件输出流”对应的BufferedWriter
    // 它对应缓冲区的大小是16,即缓冲区的数据>=16时,会自动将缓冲区的内容写入到输出流。
    try {
      File file = new File("bufferwriter.txt");
      BufferedWriter out =
         new BufferedWriter(
           new FileWriter(file));

      // 将ArrayLetters数组的前10个字符写入到输出流中
      out.write(ArrayLetters, 0, 10);
      // 将“换行符\n”写入到输出流中
      out.write('\n');

      out.flush();
      //readUserInput() ;

      out.close();
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    } catch (SecurityException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }
  }

  /**
   * 读取用户输入
   */
  private static void readUserInput() {
    System.out.println("please input a text:");
    Scanner reader=new Scanner(System.in);
    // 等待一个输入
    String str = reader.next();
    System.out.printf("the input is : %s\n", str);
  }
}

运行结果: 生成文件“bufferwriter.txt”,文件的内容是“abcdefghij”。

相关文章

  • Java MyBatis-Plus之初始MyBatis

    Java MyBatis-Plus之初始MyBatis

    MyBatis-Plus是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做修改,为简化开发、提高效率而生,本文给大家介绍MyBatis-Plus简介和快速入门教程,需要的朋友参考下吧
    2021-10-10
  • 聊聊为什么要使用BufferedReader读取File

    聊聊为什么要使用BufferedReader读取File

    这篇文章主要介绍了为什么要使用BufferedReader读取File,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • SpringBoot开发实战之自动配置

    SpringBoot开发实战之自动配置

    SpringBoot的核心就是自动配置,自动配置又是基于条件判断来配置Bean,下面这篇文章主要给大家介绍了关于SpringBoot开发实战之自动配置的相关资料,需要的朋友可以参考下
    2021-08-08
  • 后端返回各种图片形式在前端的转换及展示方法对比

    后端返回各种图片形式在前端的转换及展示方法对比

    这篇文章主要给大家介绍了关于后端返回各种图片形式在前端的转换及展示方法对比的相关资料,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2023-06-06
  • 解析ConcurrentHashMap: 红黑树的代理类(TreeBin)

    解析ConcurrentHashMap: 红黑树的代理类(TreeBin)

    ConcurrentHashMap是由Segment数组结构和HashEntry数组结构组成。Segment的结构和HashMap类似,是一种数组和链表结构,今天给大家普及java面试常见问题---ConcurrentHashMap知识,一起看看吧
    2021-06-06
  • java读取properties文件的方法实例分析

    java读取properties文件的方法实例分析

    这篇文章主要介绍了java读取properties文件的方法,实例分析了java读取在项目中与不在项目中properties文件的相关技巧,需要的朋友可以参考下
    2015-06-06
  • SpringBoot如何动态改变日志级别

    SpringBoot如何动态改变日志级别

    这篇文章主要介绍了SpringBoot如何动态改变日志级别,帮助大家更好的理解和使用springboot框架,感兴趣的朋友可以了解下
    2020-12-12
  • Java数组,去掉重复值、增加、删除数组元素的方法

    Java数组,去掉重复值、增加、删除数组元素的方法

    下面小编就为大家带来一篇Java数组,去掉重复值、增加、删除数组元素的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10
  • MyBatis实现多表联合查询resultType的返回值

    MyBatis实现多表联合查询resultType的返回值

    这篇文章主要介绍了MyBatis多表联合查询resultType的返回值,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Spring框架的JdbcTemplate使用

    Spring框架的JdbcTemplate使用

    它是 Spring 框架中提供的一个对象,是对原始 Jdbc API 对象的简单封装。本文就来介绍一下Spring框架的JdbcTemplate使用,感兴趣的可以了解一下
    2021-09-09

最新评论