输入输出操作通过字节流就可以实现,为什么需要字符流呢?
这是因为,同其它许多程序设计语言使用ASCII字符集不同,JAVA使用Unicode
编码表示字符。
ASCII符集是以一个字节(8比特)表示一个字符,所以可以认为一个字符就是一个字节。但Unicode编码是用两个字节(16比特)表示一个字符,这时字节与字符就不一样了。
为了实现与其他程序语言及不同平台之间交互,Java提供16位的数据流处理方案。
字符流也分为输入字符流和输出字符流,分别对应Reader和Writer。
和InputStream类和OutputStream类一样,Reader和Writer也是抽象类。编程时根据需要,选择子类生成对象。
Reader类提供了多个从字符输入流中读取字符的方法:
该方法读取一个字符,返回范围在0和65535之间的int值。如果达到了
输入流的末尾,则返回‐1。
该方法与InputStream的read方法类似,不同的是,参数中的数组不再是
byte数组,而是char数组。
• public int read(char [] cbuf, int off, int len) ;
该方法读取 len 个字符,存储到字符数组从 off 开始的位置中。
Reader作为抽象类,有多个非抽象的子类,其中最常用的包括 FileReader、BufferedReader
等等。
FileReader类从InputStreamReader类继承而来。该类按字符读取流中数据。
FileReader类中读取字符流的方法如下表所示:
FileReader类并未包含从文件中读取一行的方法。
而在读取纯文本文件时,按行读取是开发人员最常用的方法。
而BufferedReader类则弥补了这一缺憾,该类包含了下列方法:
readLine方法读取一个文本行。通过下列字符之一即可认为某行已终止:
换行 (‘n’)、回车 (‘r’) 或回车后直接跟着换行。方法返回包含该行内容的字符串,不包含任何行终止符,如果已到达流末尾,则返回 null。
BufferedReader类的readLine方法可能是读取纯文本文件时最常用的方法。
如果想从纯文本文件中按行读取内容,很显然,把BufferedReader与FileReader两个类结合使用是很直观的一种想法。
而BufferedReader确实也提供了下列构造方法:
public BufferedReader(Reader in)
该构造方法创建一个使用默认大小输入缓冲区的缓冲字符输入流。
因此,可以通过如下代码来结合使用上述两个类:
BufferedReader br = new BufferedReader(new FileReader(“d.txt"));
在Java 输入输出处理编程中,上述多个类的结合使用编程方式非常常见。这种方式,使用
了设计模式中的装饰模式。
在上述代码中,对创建得到的 FileReader 对象使用 BufferedReader对象进行了装饰和增强,从而可以对已有的 FileReader 对象来调用readLine 这个FileReader 类并没有定义的方法。
Writer类的主要方法包括:
public void write(String str);
public void write(String str, int off, int len);
public void close();
public void flush();
File的构造方法
File的方法