JAVA基础知识IO流(文本文件读取方式一)

JAVA基础知识IO流(文本文件读取方式一)

文本文件的读取使用的是FileReader类,FileReader类是Reader类的子类

  • Reader类
  • FileReader类
  • FileReader类读取文本文件
  • *Windows系统的文件的结束标识

Reader类

用于读取字符流的抽象类。子类必须实现的方法只有 read(char[], int, int) 和 close()。但是,多数子类将重写此处定义的一些方法,以提供更高的效率和/或其他功能。

直接已知子类:
BufferedReader, CharArrayReader, FilterReader, InputStreamReader, PipedReader, StringReader
子类的名称前缀是表示类的功能,后缀是父类的名称。
主要的子类有:InputStreamReader,FileReader等

FileReader类

用来读取字符文件的便捷类。此类的构造方法假定默认字符编码(默认编码指的是当前默认编码)和默认字节缓冲区大小都是适当的。

构造函数:FileReader(String fileName)
在给定从中读取数据的文件名的情况下创建一个新 FileReader。

FileReader类读取文本文件

public int read() throws IOException
读取单个字符。
返回:
作为整数读取的字符,范围在 0 到 65535 之间 (0x00-0xffff),如果已到达流的末尾,则返回 -1
抛出:
IOException - 如果发生 I/O 错误

Windows系统的文件的结束标识

关于末尾返回-1的解释:
FileReader fr=new FileReader(“Demo.txt”);当创建一个FileReader对象后,系统将字符流和硬盘上Demo文件相关联。
fr.read();调用该方法后,系统进行硬件操作,硬盘上的指针指向Demo文件的第一个字符,读取并返回字符对应的整数
再次调用read()方法时,硬盘的指针指向下一个字符,以此类推。
硬盘上存放着很多文件,文本文件,多媒体文件等等,需要分隔符来区分开,也就是说一个文件的末尾需要一个结束的标识。
windows系统的结束标识由系统自己定义,java能够判断这个标识,并返回-1表示结束。

代码块

代码块语法遵循标准markdown代码,例如:

import java.io.*;
class  day1810
{
    public static void main(String[] args) 
    {
        FileReader fr=null;
        try
        {
            //创建一个文件读取流对象,和指定名称的文件相关联
            //要保证该文件是已经存在的,如果不存在,会发生异常FileNotFoundException
            fr=new FileReader("ReaderDemo.txt");

            //调用读取流对象的read方法
            //read():一次读一个字符,而且会自动往下读,

            int ch=0;
            while((ch=fr.read())!=-1)
            {
                System.out.print((char)ch);
            }
        }
        catch (IOException e)
        {
            e.printStackTrace();
        }
        finally
        {
            try
            {
                if(fr!=null)
                {
                    fr.close();
                }
            }
            catch (IOException e)
            {
            e.printStackTrace();
            }           
        }
    }
}

你可能感兴趣的:(Java基础知识IO)