缓冲流

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( )——————读取一个文本行。读取一行数据。
行的终止符号—————————通过下列字符即可认为某行已终止————换行(‘ ’)、回车(‘ ’)或者回车后直接跟着换行( )。
返回值
包含改行内容的字符串,不包含任何终止符,如果已达流末尾,则放回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<String, String> 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();
    }
}

原文地址:https://www.cnblogs.com/sy130908/p/11497059.html