zoukankan      html  css  js  c++  java
  • java字符流

    一  字符流

    1 字符输入流Reader

    是读取字符流的抽象超类

     read():读取单个字符并返回

     read(char[]):将数据读取到数组中,并返回读取的个数。

    1.1  FileReader类

    它是Reader类的实现类

    构造方法:

    使用字符输入流

    1 单个字节读取

    public static void method01() throws IOException{
            //创建字符输入流
            FileReader fr=new FileReader("E:\java\demo.txt");
            int len=0;
            while((len=fr.read())!=-1){
                System.out.println((char)len);
            }
            //释放资源
            fr.close();
        }

    2 用缓冲容器

    public static void method02() throws IOException{
            FileReader fr=new FileReader("E:\java\demo.txt");
            //缓冲容器
            char[] ch=new char[1024];
            int len=0;
            while((len=fr.read(ch))!=-1){
                System.out.println(new String(ch,0,len));
            }
            //释放资源
            fr.close();
        }

    2  字节输出流 Writer

    Writer是写入字符流的抽象类

    2.1 FileWriter类

    构造方法:

    写入字符到文件时,要先进行流的刷新,再进行流的关闭,用flush

        public static void method03() throws IOException{
            FileWriter fw=new FileWriter("E:\java\demo.txt",true);
            //走ASCII
            fw.write(100);
            fw.flush();
            char[] ch={'a','中','b'};
            fw.write(ch);
            fw.flush();
            fw.write("你好,小猪佩奇");
            fw.flush();
            fw.close();
        }

    3 flush()与close()的区别

    flush():将流中的缓冲区缓冲的数据刷新到目的地中,刷新后,流还可以继续使用。

    close():关闭资源,但在关闭前会将缓冲区中的数据先刷新到目的地,否则丢失数据,然后在关闭流。流不可以使用。如果写入数据多,一定要一边写一边刷新,最后一次可以不刷新,由close完成刷新并关闭。

    4.字符流的练习

    复制文本文件

    //复制文本文件
        public static void copy() throws IOException{
            //数据源
            FileReader fr=new FileReader("E:\java\demo.txt");
            //目的地
            FileWriter fw=new FileWriter("E:\java\a\demo.txt");
            //开始复制
            int len=0;
            char[] ch=new char[1024];
            while((len=fr.read(ch))!=-1){
                fw.write(ch,0,len);
                fw.flush();
            }
            fw.close();
        }
  • 相关阅读:
    [解题报告]256 Quirksome Squares
    [解题报告]369 Combinations
    [解题报告]10696 f91
    [解题报告]483 Word Scramble
    [解题报告]10041 Vito's Family
    [解题报告]686 Goldbach's Conjecture (II)
    [解题报告]151 Power Crisis
    [解题报告]10079 Pizza Cutting
    [解题报告]495 Fibonacci Freeze
    [解题报告]541 Error Correction
  • 原文地址:https://www.cnblogs.com/zzq123/p/10222128.html
Copyright © 2011-2022 走看看