预计阅读时间: 11 分钟
流(stream)的概念源于UNIX中管道(pipe)的概念。
一个流,必有源端和目的端,它们可以是计算机内存的某些区域,也可以是磁盘文件,甚至可以是Internet上的某个URL。
根据流的方向,流可分为两类:输入流和输出流。用户可以从输入流中读取信息,但不能写它。相反,对输出流,只能往输入流写,而不能读它。
java.io包中的类对应两类流,一类流直接从指定的位置(如磁盘文件或内存区域)读或写,这类流称为结点流(node stream),其它的流则称为过滤器(filters)。
过滤器输入流往往是以其它输入流作为它的输入源,经过过滤或处理后再以新的输入流的形式提供给用户,过滤器输出流的原理也类似。
InputStream是所有字节输入流的祖先,而OutputStream是所有字节输出流的祖先。
FileInputStream和FileOutputStream 这两个类属于结点流,第一个类的源端和第二个类的目的端都是磁盘文件,它们的构造方法允许通过文件的路径名来构造相应的流。
如: FileInputStream infile = new FileInputStream("myfile.dat"); FileOutputStream outfile = new FileOutputStream("results.dat");
要注意的是,构造FileInputStream, 对应的文件必须存在并且是可读的,而构造FileOutputStream时,如输出文件已存在,则必须是可覆盖的。
package com.hxw.io; import java.io.*; public class FileCopy { public static void main(String[] args) { // TODO自动生成的方法存根 byte[] buffer=new byte[512]; //一次取出的字节数大小,缓冲区大小 int numberRead=0; FileInputStream input=null; FileOutputStream out =null; try { input=new FileInputStream("D:/David/Java/java 高级进阶/files/tiger.jpg"); out=new FileOutputStream("D:/David/Java/java 高级进阶/files/tiger2.jpg"); //如果文件不存在会自动创建 while ((numberRead=input.read(buffer))!=-1) { //numberRead的目的在于防止最后一次读取的字节小于buffer长度, out.write(buffer, 0, numberRead); //否则会自动被填充0 } } catch (final IOException e) { // TODO自动生成的 catch 块 e.printStackTrace(); }finally{ try { input.close(); out.close(); } catch (IOException e) { // TODO自动生成的 catch 块 e.printStackTrace(); } } } }
BufferedInputStream和BufferedOutputStream 它们是过滤器流,其作用是提高输入输出的效率。
DataInputStream和DataOutputStream 这两个类创建的对象分别被称为数据输入流和数据输出流。
这是很有用的两个流,它们允许程序按与机器无关的风格读写Java数据。所以比较适合于网络上的数据传输。
这两个流也是过滤器流,常以其它流如InputStream或OutputStream作为它们的输入或输出。
Reader是所有读取字符串输入流的祖先,而writer是所有输出字符串的祖先。
字符流主要是用来处理字符的。Java采用16位的Unicode来表示字符串和字符,对应的字符流按输入和输出分别称为readers和writers。
InputStreamReader和OutputStreamWriter
在构造这两个类对应的流时,它们会自动进行转换,将平台缺省的编码集编码的字节转换为Unicode字符。对英语环境,其缺省的编码集一般为ISO8859-1。
BufferedReader和BufferedWriter
这两个类对应的流使用了缓冲,能大大提高输入输出的效率。这两个也是过滤器流,常用来对InputStreamReader和OutputStreamWriter进行处理。
package com.hxw.io; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; import java.util.Iterator; public class FileConcatenate { /** * 包装类进行文件级联操作 */ public static void main(String[] args) { // TODO自动生成的方法存根 try { concennateFile(args); } catch (IOException e) { // TODO自动生成的 catch 块 e.printStackTrace(); } } public static voidconcennateFile(String...fileName) throws IOException{ String str; //构建对该文件您的输入流 BufferedWriter writer=new BufferedWriter(new FileWriter("D:/David/Java/java 高级进阶/files/copy2.txt")); for(String name: fileName){ BufferedReader reader=new BufferedReader(new FileReader(name)); while ((str=reader.readLine())!=null) { writer.write(str); writer.newLine(); } } } }
像RandomAccessFile类,序列化接口。
ObjectInputStream 和ObjectOutputStream ,该流允许读取或写入用户自定义的类,但是要实现这种功能,被读取和写入的类必须实现Serializable接口。
Java有一种特殊类型的IO数据流——DataOutputStream——它可以保证“无论数据来自何种机器,只要使用一个DataInputStream收取这些数据,就可用本机正确的格式保存它们。