Java
的字节流
可以看出,InputStream是所有字节输入流
的祖先,而OutputStream是所有字节输出流
的祖
先。
InputStream
该类是一个抽象类,其方法包括:
int read()
int read(byte[])
int
read(byte[],int,int)
read(byte[],int,int)
这三个方法可从输入流
读入字节或字节数组。要注意的是无
参数的read()方法返回一个0至255之间的整数或-1, -1代表遇到了流
的结束,其它对应读入的字节。
后两种方法
则将字节读入参数给定的字节数组,返回值是实际读入的字节数或-1(遇到了流
结束)。第三个read方法的后两个参数分别给出
读入的起始位置和读入的最大字节数。
则将字节读入参数给定的字节数组,返回值是实际读入的字节数或-1(遇到了流
结束)。第三个read方法的后两个参数分别给出
读入的起始位置和读入的最大字节数。
InputStream还有一些其它方法,如:
void close() //关闭流
int
available() //报告流
中直接可读的字节数
skip(long) //跳过流
中指定的字节
available() //报告流
中直接可读的字节数
中指定的字节
OutputStream
OutputStream也是一个抽象类。它的主要方法包括:
void
write(int)
void write(byte[])
void write(byte[],int,int)
write(int)
其
中第一个方法的int型的参数对应要写入的字节,后两个方法的参数与InputStream类似。
void close()
//关闭输出流
void flush() //强行将写入缓冲区中剩余的数据写入
//关闭输出流
FileInputStream
和FileOutputStream
这两个类属于结点流
,第一个类的源端和第二个类的目的端都是磁盘文
件,它们的构造方法允许通过文件的路径名来构造相应的流
。如:
FileInputStream infile = new
FileInputStream("myfile.dat");
FileOutputStream outfile = new
FileOutputStream("results.dat");
件,它们的构造方法允许通过文件的路径名来构造相应的流
FileInputStream("myfile.dat");
FileOutputStream("results.dat");
要注意的是,构造FileInputStream,
对应的文件必须存在并且是可读的,而构造FileOutputStream时,如输出文件已存在,则必须是可覆盖的。
BufferedInputStream
和BufferedOutputStream
它们是过滤器流
,其作用是提高输入输出的效率。
和BufferedOutputStream
DataInputStream
和DataOutputStream
这两个类创建的对象分别被称为数据输入流
和数据输出流
。这
是很有用的两个流
,它们允许程序按与机器无关的风格读写Java
数据。所以比较适合于网络上的数据传输。这
两个流
也
是过滤器流
,
常以其它流
如
InputStream或OutputStream作为它们的输入或输出。
和DataOutputStream
是很有用的两个流
两个流
是过滤器流
常以其它流
InputStream或OutputStream作为它们的输入或输出。
Java
的字符流
字
符流
主
要是用来处理字符的。Java
采用16位的Unicode来表示字符串和字符,对应的字符流
按输入和输出分别称为
readers和writers。
要是用来处理字符的。Java
readers和writers。
InputStreamReader和OutputStreamWriter
在构造这两个类对应的流
时,
它们会自动进行转换,将平台缺省的编码集编码的字节转换为Unicode字符。对英语环境,其缺省的编码集一般为ISO8859-1。
它们会自动进行转换,将平台缺省的编码集编码的字节转换为Unicode字符。对英语环境,其缺省的编码集一般为ISO8859-1。
BufferedReader
和BufferedWriter
这两个类对应的流
使用了缓冲,能大大提高输入输出的效率。这两个也是过滤器流
,常用来对InputStreamReader和OutputStreamWriter进行处理。如:
和BufferedWriter