zoukankan      html  css  js  c++  java
  • 缓冲流

    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();
        }
    }

  • 相关阅读:
    Java求区间连续最大和的三种解法(含输出起始位置)
    Java批量操作和遍历文件程序收集
    FastJson序列化部分字段的方法
    Spring源码之一步步拓展实现spring-mybatis
    Spring源码之BeanFactoryPostProcessor的执行顺序
    Classpath entry points to a non-existent location:D:libjavajdk8jrelibextaccess-bridge-32.jar
    编译Spring源码省心小贴士
    (转)HttpServletResquest对象
    (转)ServletConfig与ServletContext
    Oracle复习(复习精简版v1.0)
  • 原文地址:https://www.cnblogs.com/sy130908/p/11497059.html
Copyright © 2011-2022 走看看