详细解读Java编程中面向字符的输入流
字符流是针对字符数据的特点进行过优化的,因而提供一些面向字符的有用特性,字符流的源或目标通常是文本文件。 reader和writer是java.io包中所有字符流的父类。由于它们都是抽象类,所以应使用它们的子类来创建实体对象,利用对象来处理相关的读写操作。reader和writer的子类又可以分为两大类:一类用来从数据源读入数据或往目的地写出数据(称为节点流),另一类对数据执行某种处理(称为处理流)。
面向字符的输入流类都是reader的子类,其类层次结构如图所示。
下表列出了 reader 的主要子类及说明。
reader 所提供的方法则如这张表所示,可以利用这些方法来获得流内的位数据:
使用 filereader 类读取文件
filereader 类是 reader 子类 inputstreamreader 类的子类,因此 filereader 类既可以使用reader 类的方法也可以使用 inputstreamreader 类的方法来创建对象。
在使用 filereader 类读取文件时,必须先调用 filereader()构造方法创建 filereader 类的对象,再调用 read()方法。filereader 构造方法的格式为:
public filereader(string name); //根据文件名创建一个可读取的输入流对象
【例】利用 filereader 类读取纯文本文件的内容
import java.io.*; class ep10_1{ public static void main(string args[]) throws ioexception{ char a[]=new char[1000]; //创建可容纳 1000 个字符的数组 filereader b=new filereader("ep10_1.txt"); int num=b.read(a); //将数据读入到数组 a 中,并返回字符数 string str=new string(a,0,num); //将字符串数组转换成字符串 system.out.println("读取的字符个数为:"+num+",内容为:\n"); system.out.println(str); } }
需要注意的是,java 把一个汉字或英文字母作为一个字符对待,回车或换行作为两个字符对待。
使用 bufferedreader 类读取文件
bufferedreader 类是用来读取缓冲区中的数据。使用时必须创建 filereader 类对象,再以该对象为参数创建 bufferedreader 类的对象。bufferedreader 类有两个构造方法,其格式为:
public bufferedreader(reader in); //创建缓冲区字符输入流 public bufferedreader(reader in,int size); //创建输入流并设置缓冲区大小
【例】利用 bufferedreader 类读取纯文本文件的内容
import java.io.*; class ep10_2{ public static void main(string args[]) throws ioexception{ string oneline; int count=0; try{ filereader a=new filereader("ep10_1.txt"); bufferedreader b=new bufferedreader(a); while((oneline=b.readline())!=null){ //每次读取 1 行 count++; //计算读取的行数 system.out.println(oneline); } system.out.println("\n 共读取了"+count+"行"); b.close(); } catch(ioexception io){ system.out.println("出错了!"+io); } } }
需要注意的是,执行 read()或 write()方法时,可能由于 io 错误,系统抛出 ioexception 异常,需要将执行读写操作的语句包括在 try 块中,并通过相应的 catch 块来处理可能产生的异常。