标签:
java.io
类 FileReader
java.lang.Object
┗java.io.Reader
┗java.io.InputStreamReader
┗java.io.FileReader
所有实现的接口:Closeable,Readable
public class FileReader extends InputStreamReader
用来读取字符文件的便捷类。此类的构造方法假定默认字符编码和默认字节缓冲区大小都是适当的。要自己指定这些值,可以先在FileInputStream上构造一个InputStreamReader。
FileReader用于读取字符流。要读取原始字节流,请考虑使用FIleInputStream。
字段摘要
从类 java.io.Reader 继承的字段
lock
构造方法摘要
FileReader (File file);
在给定从中读取数据的File的情况下创建一个新FileReader。
FileReader(FileDescriptor fd)
在给定从中读取数据的FileDescriptor 的情况下创建一个新FileReader。
FileReader(String fileName)
在给定从中读取数据的文件名的情况下创建一个新FileReader
方法摘要
从类 java.io.InputStreamReader 继承的方法
close,getEncoding,read,ready
从类 java.io.Reader 继承的方法
mark,markSupported,read,read,reset,skip
从类java.lang.Object 继承的方法
clone,equals,finalize,getClass,hashCodde,notify,notifyAll,toString,wait,wait,wait
构造方法详细信息
FileReader
Public FileReader(String filename) throws FileNotFoundException
在给定从中读取数据的文件名的情况下创建一个新 FileReader。
参数:
fileName – 要从中读取数据的文件的名称
抛出:
FileNotFoundException – 如果指定文件不存在,或者它是一个目录,而不是一个常规文件,抑或因为 其他某些原因而无法打开进行读取。
FileReader
public FileReader(FileDescriptor fd)
在给定从中读取数据的FileDescriptor 的情况下创建一个新FileReader。
参数:
fd – 要从中读取数据的FileDescriptor。
Java.io
类 InputStreamReader
Java.lang.Object
┗java.io.Reader
┗java.io.InputStreamReader
所有已实现的接口:
Closeable,Readable
直接已知子类:
FileReader
public class InputStreamReader extends Reader
InputStreamReader 是字节流通向字符流的桥梁:它使用指定的charset读取字节并将其解码为字符。它使用的字符集可以由名称指定或显示给定,或者可以接收平台默认的字符集。
每次调用InputStreamReader 中的一个read()方法都会导致从底层输入流读取一个或多个字节。要启用从字节到字符的有效转换,可以提前从底层流读取更多的字节,使其超过满足当前读取操作所需的字节。
为了达到最高效率,可要考虑在 BufferedReader 内包装InputStreamReader。例如:
BufferedStream in = new BufferedStream(new InputStreamReader(System.in));
字段摘要
从类 java.io.Reader 继承的字段
lock
构造方法摘要
InputStreamReader(InputStream in)
创建一个使用默认字符集的InputStreamReader。
InputStreamReader(InputStream in,Charset cs)
创建使用给定字符集的 InputStreamReader。
InputStreamReader(InputStream in,String charsetName)
创建使用指定字符集的 InputStreamReader。
InputStreamReader(InputStream in,CharsetDecoder dec)
创建使用给定字符集额解码器的 INputStreamReader。
方法摘要
void close() 关闭该流并释放与之关联的所有资源。
String getEncoding() 返回此流使用的字符编码的名称。
Int read() 读取单个字符,返回字符的ASCII码。
Int read(char[] cbuf,int offset,int length) 将字符读入数组中的某一部分。
boolean ready() 判断此流是否已经准备好用于读取。
从类 java.io.Reader 继承的方法
mark,markSupported,read,read,reset,skip
从类 java.lang.Object继承的方法
Clone,equals,finalize,getClass,hashCode,notify,notifyAll,toString,wait,wait,wait
构造方法详细信息
InputStreamReader
public InputStreamReader(InputStream in)
创建一个使用默认字符集的 InputStreamReader。
参数:
in – InputStream
InputStreamReader
public InputStreamReader(InputStream in, String charsetName)throws UnsupportedEncodingException
创建使用指定字符集的 InputStreamReader。
参数:
in - InputStream
charsetName - 受支持的 charset 的名称
抛出:
UnsupportedEncodingException - 如果不支持指定的字符集
InputStreamReader
public InputStreamReader(InputStream in, Charset cs)
创建使用给定字符集的 InputStreamReader。
参数:
in - InputStream
cs - 字符集
InputStreamReader
public InputStreamReader(InputStream in,CharsetDecoder dec)
创建使用给定字符集解码器的 InputStreamReader。
参数:
in - InputStream
dec - 字符集解码器
方法详细信息
getEncoding
public String getEncoding()
返回此流使用的字符编码的名称。
如果该编码有历史上用过的名称,则返回该名称;否则返回该编码的规范化名称。
如果使用 InputStreamReader(InputStream,String)构造方法创建此实例,则返回的由此编码生成的唯一名称可能与传递给该构造方法的名称不一样。
如果流已经关闭,则此方法会返回null。
返回:
此编码的历史名称;如果流已经关闭,则返回null
read
public int read()throws IOException
读取单个字符。
覆盖:
类Reader中的read
返回:
读取的字符的ASCII码;如果已经到达流的末尾,则返回-1
抛出:
IOException –如果发生I/O错误
read
public int read(char[] cbuf,int offset,int length)throws IOException
将字符读入数组中的某一部分。
指定者:
类Reader中的read
参数:
cbuf – 目标缓冲区
offset – 从此处开始存储字符的偏移量
length – 要读取的最大字符数
返回:
读取的字符数,如果已经到达流的末尾,则返回-1
抛出:
IOException – 如果发生I/O错误
ready
public Boolean ready() throws IOException
判断此流是否已经准备好用于读取。如果其输入缓冲区不为空,或者可从底层字节流读取字节,则InputStreamReader已做好被读的准备。
覆盖:
类Reader中的ready
返回:
如果保证一个read()不阻塞输入,则返回True,否则返回false。
注意,返回false并不保证阻塞下一次读取。
抛出:
IOException – 如果发生I/O 错误
Close
Public void close() throws IOException
从类Reader复制的描述
关闭该流并释放与之关联的所有资源。
在关闭该流后,在调用read(),ready(),mark(),reset()或skip()将抛出IOException。
关闭以前关闭的流无效。
指定者:
接口Closeable中的close
指定者:
类Reader中的close
抛出:
IOException – 如果发生I/O错误
java.io
类 Reader
java.lang.Object
┗java.io.Reader
所有已实现的接口:
直接已知子类:
BufferedReader, CharArrayReader, FilterReader, InputStreamReader, PipedReader, StringReader
public abstract class Reader extends Object implements Readable, Closeable
用于读取字符流的抽象类。子类必须实现的方法只有 read(char[], int, int) 和 close()。但是,多数子类将重写此处定义的一些方法,以提供更高的效率和/或其他功能。
字段摘要 |
|
protected Object |
lock |
构造方法摘要 |
|
protected |
Reader()
|
protected |
方法摘要 |
|
abstract void |
close()
|
void |
mark(int readAheadLimit)
|
boolean |
markSupported()
|
int |
read()
|
int |
read(char[] cbuf)
|
abstract int |
read(char[] cbuf,
int off, int len) |
int |
read(CharBuffer target) |
boolean |
ready()
|
void |
reset()
|
long |
skip(long n)
|
从类 java.lang.Object 继承的方法 |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
字段详细信息 |
protected Object lock
用于同步针对此流的操作的对象。为了提高效率,字符流对象可以使用其自身以外的对象来保护重要部分。因此,子类应使用此字段中的对象,而不是 this 或者同步的方法。
构造方法详细信息 |
protected Reader()
创建一个新的字符流 reader,其重要部分将同步其自身的 reader。
protected Reader(Object lock)
创建一个新的字符流 reader,其重要部分将同步给定的对象。
参数:
lock - 要同步的对象。
方法详细信息 |
public int read(CharBuffer target)
throws IOException
试图将字符读入指定的字符缓冲区。缓冲区可照原样用作字符的存储库:所做的唯一改变是 put 操作的结果。不对缓冲区执行翻转或重绕操作。
指定者:
参数:
target - 要将字符读入的缓冲区
返回:
添加到缓冲区的字符数量,如果此字符源位于缓冲区末端,则返回 -1
抛出:
IOException - 如果发生 I/O 错误
NullPointerException - 如果目标为空
ReadOnlyBufferException - 如果目标是一个只读缓冲区
public int read()
throws IOException
读取单个字符。在字符可用、发生 I/O 错误或者已到达流的末尾前,此方法一直阻塞。
用于支持高效的单字符输入的子类应重写此方法。
返回:
作为整数读取的字符,范围在 0 到 65535 之间 (0x00-0xffff),如果已到达流的末尾,则返回 -1
抛出:
IOException - 如果发生 I/O 错误
public int read(char[] cbuf)
throws IOException
将字符读入数组。在某个输入可用、发生 I/O 错误或者已到达流的末尾前,此方法一直阻塞。
参数:
cbuf - 目标缓冲区
返回:
读取的字符数,如果已到达流的末尾,则返回 -1
抛出:
IOException - 如果发生 I/O 错误
public abstract int read(char[] cbuf,
int off,
int len)
throws IOException
将字符读入数组的某一部分。在某个输入可用、发生 I/O 错误或者到达流的末尾前,此方法一直阻塞。
参数:
cbuf - 目标缓冲区
off - 开始存储字符处的偏移量
len - 要读取的最多字符数
返回:
读取的字符数,如果已到达流的末尾,则返回 -1
抛出:
IOException - 如果发生 I/O 错误
public long skip(long n)
throws IOException
跳过字符。在某个字符可用、发生 I/O 错误或者已到达流的末尾前,此方法一直阻塞。
参数:
n - 要跳过的字符数
返回:
实际跳过的字符数
抛出:
IllegalArgumentException - 如果 n 为负。
IOException - 如果发生 I/O 错误
public boolean ready()
throws IOException
判断是否准备读取此流。
返回:
如果保证下一个 read() 不阻塞输入,则返回 True,否则返回 false。注意,返回 false 并不保证阻塞下一次读取。
抛出:
IOException - 如果发生 I/O 错误
public boolean markSupported()
判断此流是否支持 mark() 操作。默认实现始终返回 false。子类应重写此方法。
返回:
当且仅当此流支持此 mark 操作时,返回 true。
public void mark(int readAheadLimit)
throws IOException
标记流中的当前位置。对 reset() 的后续调用将尝试将该流重新定位到此点。并不是所有的字符输入流都支持 mark() 操作。
参数:
readAheadLimit - 在仍保留该标记的情况下,对可读取字符数量的限制。在读取这样多的字符后,尝试重置流可能会失败。
抛出:
IOException - 如果该流不支持 mark(),或者发生一些其他 I/O 错误
public void reset()
throws IOException
重置该流。如果已标记该流,则尝试在该标记处重新定位该流。如果已标记该流,则以适用于特定流的某种方式尝试重置该流,例如,通过将该流重新定位到其起始点。并不是所有的字符输入流都支持 reset() 操作,有些支持 reset() 而不支持 mark()。
抛出:
IOException - 如果尚未标记流,或者该标记已失效,或者该流不支持 reset(),或者发生一些其他 I/O 错误
public abstract void close()
throws IOException
关闭该流并释放与之关联的所有资源。在关闭该流后,再调用 read()、ready()、mark()、reset() 或 skip() 将抛出 IOException。关闭以前关闭的流无效。
指定者:
抛出:
IOException - 如果发生 I/O 错误
标签:
原文地址:http://www.cnblogs.com/zzuLiang/p/4679108.html