缓冲流

缓冲流的原理

缓冲流_第1张图片
java.io.BufferedOutputStream extends OutputStream

BufferedOutputStream ————字节缓冲输出流

继承自父类的共性方法

  • public void close()——关闭此输出流并释放与此流相关联的任何系统资源。
  • public void flush()——刷新此输出流并强制任何缓冲的输出字节被写出。
  • public void write(byte[ ] b)——将b.length字节从指定的字节数组写入到此输出流。
  • public void write(byte[ ] b,int off,int len)——从指定的字节数组写入len字节,从偏移量off开始输出到此输出流。
  • public abstract void write(int b)——将指定的字节输出流。
    构造方法
  • BufferedOutputStream (OutputStream out)——创建一个新的缓冲输出流,以将数据写入指定的底层输出流。
  • BufferedOutputStream (OutputStream out,int
    size)——创建一个新的缓冲输出流,以将具有指定缓冲区大小的数据写入指定的底层输出流。
    参数
  • OutputStream out————字节输出流
    我们可以传递FileOutPutStream,缓冲流会给FileOutPutStream增加一个缓冲区,提高FileOutPutStream的写入效率。
  • int size—————————指定缓冲流内部缓冲区的大小,不指定默认。
    使用步骤(重点)
    1.创建FileOutPutStream对象,构造方法中绑定要输出的目的地。
    2.创建BufferedOutputStream对象,构造方法中传递FileOutPutStream对象,提高FileOutPutStream对象效率。
    3.使用BufferedOutputStream对象中的方法write,把数
    据写入到内部缓冲区中。
    4.使用BufferedOutputStream对象中的方法flush,把内部缓冲区中的数据,刷新到文件中。
    5.释放资源(会先调用flush方法刷新数据,第四步可以省略)。

java.io.BufferedIutputStream extends IutputStream

BufferedIntputStream ————字节缓冲输入流

继承自父类的共性方法

  • int read()——从输入流中读取数据的下一个字节。
  • int read(char[ ] cbuf)——从输入流中读取一定数量的字节,并将其存储在缓冲区数组b中。
  • void close()——关闭此输入流并释放与此流相关联的任何系统资源。
  • 构造方法
  • BufferedIntputStream (IutputStream in)——创建一个BufferedIntputStream 并保存其参数,即输入流in,以便将来使用。
  • BufferedIntputStream (IntputStream in,int
    size)——创建具有指定缓冲区大小的BufferedIntputStream 保存其参数,即输入流in。
    参数
  • IntputStream in————字节输入流
    我们可以传递FileIntPutStream,缓冲流会给FileIntPutStream增加一个缓冲区,提高FileIntPutStream的读取效率。
  • int size—————————指定缓冲流内部缓冲区的大小,不指定默认。
    使用步骤(重点)
    1.创建FileIntPutStream对象,构造方法中绑定要读取的数据。
    2.创建BufferedIntputStream 对象,构造方法中传递FileIntPutStream对象,提高FileIntPutStream对象读取效率。
    3.使用BufferedIntputStream 对象中的方法read,读取文件
    4.释放资源。

java.io.BufferedWriter extends Writer

字符缓冲输出流——BufferedWriter类

继承自父类的共性成员方法

  • public void write(int c)—————写入单个字符。

  • public void write(char[ ] cbuf)——写入字符数组。

  • abstract void write(char[ ] cbuf,int off,int len)——写入字符数组的某一部分,off数组的开始索引,len写的字符个数。

  • void write(String str)——写入字符串。

  • void write(char[ ] cbuf,int off,int len)——写入字符数组的某一部分,off字符串的开始索引,len写的字符个数。

  • void flush()——刷新该流的缓冲。

  • public void close()————————关闭此流,但要先刷新它。
    构造方法

  • BufferedWriter (Writer out)————创建一个使用默认大小输出缓冲区的缓冲字符输出流。

  • BufferedWriter (Writer out,int sz)——创建一个使用给定大小输出缓冲区的缓冲字符输出流。
    参数
    Writer out————字符输出流
    我们可以传递FileWtite,缓冲流会给FileWtite增加一个缓冲区,提高FileWtite的写入效率。
    int sz—————指定缓冲区的大小,不写默认大小。
    特有的成员方法

  • void newLine()————写入一个行分隔符。会根据不同的操作系统,获取不同的行分隔符。

使用步骤
1.创建字符缓冲输出流对象,构造方法中传递字符输出流。
2.调用字符缓冲输出流对象的方法write,把数据写入到缓冲区中。
3.调用字符缓冲输出流对象的方法flush,把内存缓冲区中的数据,刷新到文件中。
4.释放资源。
java.io.BufferedReader extends Reader

字符输入流——BufferedReader 类

继承自父类的共性成员方法

  • int read()——读取单个字符并返回。
  • int read(char[ ] cbuf)——一次读取多个字符,将字符读入数组。
  • void close()——关闭该流并释放与之关联的所有资源。
    构造方法
  • BufferedReader (Reader in)————创建一个使用默认大小的输入缓冲区的缓冲字符输入流。
  • BufferedReader (Reader in)————创建一个使用是定大小输入缓冲区的缓冲字符输入流。
    参数——————读取文件的数据源
    Reader in——字符输入流
    我们可以传递FileReader,缓冲流会给FileReader增加一个缓冲区,提高FileReader的读取效率。
    特有的成员方法
  • String readLine( )——————读取一个文本行。读取一行数据。
    行的终止符号—————————通过下列字符即可认为某行已终止————换行(‘\n’)、回车(‘\r’)或者回车后直接跟着换行(\n\r)。
    返回值
    包含改行内容的字符串,不包含任何终止符,如果已达流末尾,则放回null。
    使用步骤
    1.创建一个字符缓冲输入流对象,构造方法中传递符缓冲输入流。
    2.使用符缓冲输入流对象中的方法read/readLine读取文本。
    3.释放资源。

练习——对文本的内容进行排序

package cn.lrf.IODemo;

import java.io.*;
import java.util.HashMap;

/*练习
 * 对文本的内容进行排序
 * 按照(1,2,3...顺序进行排序)
 * 分析
 * 1.创建一个HashMap集合对象,可以存储每行文本的序号1,2,3...);value:存储每行的文本
 * 2.创建字符缓冲输入流对象,构造方法中绑定字符输入流。
 * 3.创建字符缓冲输出流对象,构造方法中绑定字符输入流。
 * 4.使用字符缓冲输入流中的方法readLine,逐行读取文本。
 * 5.对读取到的文本进行切割,获取行中的序号和文本内容。
 * 6.把切割好的序号和文本的内容存储到HashMap集合中(key序号是有序的,会自动排序1,2,3,4...)
 * 7.遍历HashMap集合,获取每一个键值对。
 * 8.把每一个键值对,拼接为一个文本行
 * 9.把拼接好的文本,使用字符缓冲输出流的方法write,写入到文件中。
 * 10.释放资源。
 * */
public class Demo05Test {
    public static void main(String[] args) throws IOException {
        // 1.创建一个HashMap集合对象,可以存储每行文本的序号1,2,3...);value:存储每行的文本
        HashMap map = new HashMap<>();
        // 2.创建字符缓冲输入流对象,构造方法中绑定字符输入流。
        BufferedReader br = new BufferedReader(new FileReader("day08-code\\src\\cn\\lrf\\IODemo\\c.txt"));
        //3.创建字符缓冲输出流对象,构造方法中绑定字符输入流。
        BufferedWriter bw = new BufferedWriter(new FileWriter("day08-code\\src\\cn\\lrf\\IODemo\\d.txt"));
        // 4.使用字符缓冲输入流中的方法readLine,逐行读取文本。
        String line;
        while ((line = br.readLine()) != null) {
            // 5.对读取到的文本进行切割,获取行中的序号和文本内容。
            String[] arr = line.split("\\.");
            //6.把切割好的序号和文本的内容存储到HashMap集合中(key序号是有序的,会自动排序1,2,3,4...)
            map.put(arr[0], arr[1]);
        }
        // 7.遍历HashMap集合,获取每一个键值对。
        for (String key : map.keySet()) {
            String value = map.get(key);
            // 8.把每一个键值对,拼接为一个文本行
            line = key + "." + value;
            // 9.把拼接好的文本,使用字符缓冲输出流的方法write,写入到文件中。
            bw.write(line);
            bw.newLine();//写换行
        }
        // 10.释放资源。

        bw.close();

        br.close();
    }
}

你可能感兴趣的:(Java语言高级)