转载

Java的IO流

预计阅读时间: 11 分钟

一、流的概念

流(stream)的概念源于UNIX中管道(pipe)的概念。

一个流,必有源端和目的端,它们可以是计算机内存的某些区域,也可以是磁盘文件,甚至可以是Internet上的某个URL。

根据流的方向,流可分为两类:输入流和输出流。用户可以从输入流中读取信息,但不能写它。相反,对输出流,只能往输入流写,而不能读它。

二、流的分类

java.io包中的类对应两类流,一类流直接从指定的位置(如磁盘文件或内存区域)读或写,这类流称为结点流(node stream),其它的流则称为过滤器(filters)。

过滤器输入流往往是以其它输入流作为它的输入源,经过过滤或处理后再以新的输入流的形式提供给用户,过滤器输出流的原理也类似。

Java的IO流

Java的字节流

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作为它们的输入或输出。

Java的字符流

Reader是所有读取字符串输入流的祖先,而writer是所有输出字符串的祖先。

Java的IO流

字符流主要是用来处理字符的。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收取这些数据,就可用本机正确的格式保存它们。

原文  http://boke.iflsy.com/archives/1291
正文到此结束
Loading...