BufferedIo

缓冲流

 缓冲流要“套接”在相应的节点流之上,对读写的数据提供了缓冲的功能,提高了读写的效率,同时增加了一些新的方法

BufferedReader(Reader in)
BufferedReader(Reader in,int sz)//sz为自定义缓冲区的大小
BufferedWriter(Writer out)
BufferedWriter(Writer out,int sz)
BufferedInputStream(InputStream in)
BufferedInputStream(InputStream in,int size)
BufferedOutputStream(OutputStream out)
BufferedOutputStream(OutputStream out,int size)
  • 缓冲输入流支持其父类的mark和reset方法
  • BufferedReader提供了ReadLine方法用于读取一行字符串(以r或n分隔)
  • BufferedWriter提供了newLine用于写入一个分隔符
  • 对于输出的缓冲流,写出的数据会先在内存中缓存,使用flush方法将会使内存中的数据立刻写出

BufferedInputStream

import java.io.*;

public class TestFileInputStream {
    public static void main(String[] args) {
        try {
            FileInputStream fis = 
                    new FileInputStream("D:/test.txt");
            BufferedInputStream bis = 
                    new BufferedInputStream(fis);
            int c = 0;
            System.out.println(bis.read());
            System.out.println(bis.read());
            bis.mark(100);//标记第100个字符,从第100个字符往外读
            for(int i = 0;i <= 10 && (c = bis.read()) != -1;i++) 
                System.out.println((char)c + " ");
            System.out.println();
            bis.reset();//回到标记
            for(int i = 0;i <= 10 && (c = bis.read()) != -1;i++)
                System.out.println((char)c + " ");
            bis.close();
        }catch(IOException e) {
            e.printStackTrace();
        }
    }
}

BufferedReader(Writer)

import java.io.*;

public class TestBuffered{

    public static void main(String[] args) {
        try {
            BufferedWriter bw = 
                    new BufferedWriter(new FileWriter("D:/test4.txt"));
            BufferedReader br = 
                    new BufferedReader(new FileReader("D:/test4.txt"));
            String s = null;
            for(int i = 1;i <= 100;i++) {//写入100行随机数
                s = String.valueOf(Math.random());
                bw.write(s);
                bw.newLine();
            }
            bw.flush();
            while((s = br.readLine()) != null) {
                System.out.println(s);
            }
            bw.close();
            br.close();
        }catch(IOException e) {
            e.printStackTrace();
        }
    }
}

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • LeetCode218. 天际线问题

     如果按照一个矩形一个矩形处理会非常麻烦,我们把这些矩形拆成两个点,一个左上角顶点,一个右上角顶点。将所有顶点按照横坐标进行排序然后开始遍历,遍历时通过一个...

    mathor
  • 条件概率和乘法公式

    mathor
  • 二分查找与二分答案(2)

    mathor
  • 玩转腾讯词向量:Game of Words(词语的加减游戏)

    上一篇文章《腾讯词向量实战:通过Annoy进行索引和快速查询》结束后,觉得可以通过Annoy做一点有趣的事,把“词类比(Word Analogy)”操作放到线上...

    AINLP
  • Multiple dex files define Lokhttp3internalwsWebSocketProtocol

    如题,在编译打包时遇到了如上错误,很明显这是一个依赖库冲突的问题,我的app下依赖一个 ad library,而 ad library有依赖了一个 htt...

    IT大飞说
  • Hierarchical softmax(分层softmax)简单描述.

    最近在做分布式模型实现时,使用到了这个函数. 可以说非常体验非常的好. 速度非常快,效果和softmax差不多. 我们知道softmax在求解的时候,它的时间...

    Gxjun
  • 重要|Flink SQL与kafka整合的那些事儿

    flink与kafka整合是很常见的一种实时处理场景,尤其是kafka 0.11版本以后生产者支持了事务,使得flink与kafka整合能实现完整的端到端的仅一...

    Spark学习技巧
  • JDBC 使用DBUtils 查询、更新(15)

    commons-dbutils是Apache组织提供的一个开源JDBC工具类库,它是对JDBC的简单封装。简化了jdbc编码的工作量

    桑鱼
  • 去中心化理论之一——什么是去中心化

    比特币是一个去中心化的货币系统,去中心化是比特币成功的关键所在。哪到底什么是“去中心化”呢?

    用户2940845
  • 有了微信小程序,谁还学ReactNative?

    从我熟悉和关注的移动开发技术栈的演进角度,讲讲微信“小程序”对移动开发技术可能会带来的变化,以及对于移动应用开发者可能带来的三点重大影响。有些文章从产品角度探讨...

    贺嘉

扫码关注云+社区

领取腾讯云代金券