博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java知多少(67)面向字符的输入流
阅读量:7225 次
发布时间:2019-06-29

本文共 2883 字,大约阅读时间需要 9 分钟。

字符流是针对字符数据的特点进行过优化的,因而提供一些面向字符的有用特性,字符流的源或目标通常是文本文件。 Reader和Writer是java.io包中所有字符流的父类。由于它们都是抽象类,所以应使用它们的子类来创建实体对象,利用对象来处理相关的读写操作。Reader和Writer的子类又可以分为两大类:一类用来从数据源读入数据或往目的地写出数据(称为节点流),另一类对数据执行某种处理(称为处理流)。

面向字符的输入流类都是Reader的子类,其类层次结构如图10-2所示。

图10-2 Reader的类层次结构图
图10-2 Reader的类层次结构图

表 10-1 列出了 Reader 的主要子类及说明。

表 10-1 Reader 的主要子类
类名 功能描述
CharArrayReader 从字符数组读取的输入流
BufferedReader 缓冲输入字符流
PipedReader 输入管道
InputStreamReader 将字节转换到字符的输入流
FilterReader 过滤输入流
StringReader 从字符串读取的输入流
LineNumberReader 为输入数据附加行号
PushbackReader 返回一个字符并把此字节放回输入流
FileReader 从文件读取的输入流

Reader 所提供的方法如表 10-2 所示,可以利用这些方法来获得流内的位数据。

表 10-2 Reader 的常用方法
方法 功能描述
void close() 关闭输入流
void mark() 标记输入流的当前位置
boolean markSupported() 测试输入流是否支持 mark
int read() 从输入流中读取一个字符
int read(char[] ch) 从输入流中读取字符数组
int read(char[] ch, int off, int len) 从输入流中读 len 长的字符到 ch 内
boolean ready() 测试流是否可以读取
void reset() 重定位输入流
long skip(long n) 跳过流内的 n 个字符

使用 FileReader 类读取文件

FileReader 类是 Reader 子类 InputStreamReader 类的子类,因此 FileReader 类既可以使用Reader 类的方法也可以使用 InputStreamReader 类的方法来创建对象。

在使用 FileReader 类读取文件时,必须先调用 FileReader()构造方法创建 FileReader 类的对象,再调用 read()方法。FileReader 构造方法的格式为:
    public FileReader(String name);  //根据文件名创建一个可读取的输入流对象
【例 10-1】利用 FileReader 类读取纯文本文件的内容

1 import java.io.*; 2 class ep10_1{ 3     public static void main(String args[]) throws IOException{ 4         char a[]=new char[1000]; //创建可容纳 1000 个字符的数组 5         FileReader b=new FileReader("ep10_1.txt"); 6         int num=b.read(a); //将数据读入到数组 a 中,并返回字符数 7         String str=new String(a,0,num); //将字符串数组转换成字符串 8         System.out.println("读取的字符个数为:"+num+",内容为:\n"); 9         System.out.println(str);10     }11 }

运行结果如图 10-3 所示:

图 10-3  例 10_1 运行结果(输出内容为文件ep10_1.txt的内容)

需要注意的是,Java 把一个汉字或英文字母作为一个字符对待,回车或换行作为两个字符对待。

使用 BufferedReader 类读取文件

BufferedReader 类是用来读取缓冲区中的数据。使用时必须创建 FileReader 类对象,再以该对象为参数创建 BufferedReader 类的对象。BufferedReader 类有两个构造方法,其格式为:

    public BufferedReader(Reader in);  //创建缓冲区字符输入流
    public BufferedReader(Reader in,int size);  //创建输入流并设置缓冲区大小
【例 10-2】利用 BufferedReader 类读取纯文本文件的内容

1 import java.io.*; 2 class ep10_2{ 3     public static void main(String args[]) throws IOException{ 4         String OneLine; 5         int count=0; 6         try{ 7                 FileReader a=new FileReader("ep10_1.txt"); 8                 BufferedReader b=new BufferedReader(a); 9                 while((OneLine=b.readLine())!=null){  //每次读取 1 行10                      count++;  //计算读取的行数11                      System.out.println(OneLine);12                 }13                 System.out.println("\n 共读取了"+count+"行");14                 b.close();15            }16            catch(IOException io){17                 System.out.println("出错了!"+io);18            }19       }20 }

运行结果如图 10-4 所示:

图 10-4  例 10_2 运行结果

需要注意的是,执行 read()或 write()方法时,可能由于 IO 错误,系统抛出 IOException 异常,需要将执行读写操作的语句包括在 try 块中,并通过相应的 catch 块来处理可能产生的异常。

系列文章:

转载于:https://www.cnblogs.com/Coda/p/4513550.html

你可能感兴趣的文章
(译).NET4.X 并行任务中Task.Start()的FAQ
查看>>
git log显示
查看>>
java中相同名字不同返回类型的方法
查看>>
Rails NameError uninitialized constant class solution
查看>>
Android 获取SDCard中某个目录下图片
查看>>
设置cookies第二天0点过期
查看>>
【转载】NIO客户端序列图
查看>>
poj_2709 贪心算法
查看>>
【程序员眼中的统计学(11)】卡方分布的应用
查看>>
文件夹工具类 - FolderUtils
查看>>
http://blog.csdn.net/huang_xw/article/details/7090173
查看>>
lua学习例子
查看>>
研究:印度气候变暖速度加剧 2040年或面临重灾
查看>>
python爬虫——爬取豆瓣TOP250电影
查看>>
C++与Rust操作裸指针的比较
查看>>
了解webpack-4.0版本(一)
查看>>
如何培养良好的编程风格
查看>>
Netty Channel源码分析
查看>>
基于 HTML5 WebGL 的 3D 机房
查看>>
Java编程——数据库两大神器:索引和锁
查看>>