• java核心学习(十四) IO框架---推回输入流


      推回输入流就是讲字节或字符数组内容推回到推回缓冲区里面,从而允许重复读取刚刚读取的内容

      当程序创建一个推回输入流时需要指定推回缓冲区的大小,默认的推回缓冲区长度为一,如果程序推回到推回缓冲区的内容超出了推回缓冲区的大小,将会引发Pushback buffer overflow 异常。

      下面看例子

      

    package IOTest;
    
    import java.io.FileReader;
    import java.io.IOException;
    import java.io.PushbackInputStream;
    import java.io.PushbackReader;
    
    public class PushbackTest {
        public static void main(String[] args){
            try(
                    PushbackReader pushbackReader = new PushbackReader(new FileReader("./src/main/java/IOTest/Push" +
                            "backTest.java"),64)
                    )
            {
                char[] buf = new char[32];
                String lastContent = "";
                int hasRead = 0;
                while ((hasRead = pushbackReader.read(buf))>0)
                {
                    String content = new String(buf,0,hasRead);
                    int targetIndex = 0;
                    if((targetIndex = (lastContent + content).indexOf("new PushbackReader"))>0){
                        pushbackReader.unread((lastContent+content).toCharArray());
                        if(targetIndex > 32)
                        {
                            buf = new char[targetIndex];
                        }
                        pushbackReader.read(buf,0,targetIndex);
                        System.out.println(new String(buf,0,targetIndex));
                        System.exit(0);
                    }
                    else{
                        System.out.println(lastContent);
                        lastContent = content;
                    }
                }
            }catch (IOException ex){
    
                ex.printStackTrace();
            }
        }
    }

    输出

      推回输入流在进行输入时先从推回缓冲区读取,当推回缓冲区中的数据读取完了之后才从输入流中读取数据。

  • 相关阅读:
    Scala依赖注入
    Scala实现树形结构
    Spark GraphX快速入门
    mysql服务自启【Linux】
    Centos7安装mysql5.6
    Scala路径依赖【内部类】
    spark查看DF的partition数目及每个partition中的数据量【集群模式】
    Python自定义异常及抛出异常
    Spark应用【根据新df更新旧df】
    Linux安装JDK
  • 原文地址:https://www.cnblogs.com/Theshy/p/7525085.html
Copyright © 2020-2023  润新知