Java IO流分析整理

原创 2013年12月05日 16:09:10

 

Java中的流,可以从不同的角度进行分类。

按照数据流的方向不同可以分为:输入流输出流

按照处理数据单位不同可以分为:字节流字符流

按照实现功能不同可以分为:节点流处理流

 

######### 输出流 & 输入流 #############

输出流:

 

 

输入流:

 

因此输入和输出都是从程序的角度来说的。

 

 

############ 字节流 & 字符流 #######################

 

字符流的由来: 因为数据编码的不同,而有了对字符进行高效操作的流对象。本质其实就是基于字节流读取时,去查了指定的码表。 字节流和字符流的区别:

  • 读写单位不同:字节流以字节(8bit)为单位,字符流以字符为单位,根据码表映射字符,一次可能读多个字节。
  • 处理对象不同:字节流能处理所有类型的数据(如图片、avi等),而字符流只能处理字符类型的数据。

结论:只要是处理纯文本数据,就优先考虑使用字符流。 除此之外都使用字节流。

 

 

############ 节点流 & 处理流 #######################

节点流:直接与数据源相连,读入或读出。

 

直接使用节点流,读写不方便,为了更快的读写文件,才有了处理流。

处理流:与节点流一块使用,在节点流的基础上,再套接一层,套接在节点流上的就是处理流。

 

 

 

 

Jdk提供的流继承了四大类:

  InputStream(字节输入流)

 

  OutputStream(字节输出流)

 

  Reader(字符输入流)

 

  Writer(字符输出流)。

 

以下是javaio中常用的流。

 

字节输入流:

字节输出流:

字符输入流:

字符输出流:

 

简单介绍其上图:

----------------------------------

对文件进行操作:FileInputStream(字节输入流),FileOutputStream(字节输出流),FileReader(字符输入流),FileWriter(字符输出流),同属节点流

 

对管道进行操作:PipedInputStream(字节输入流),PipedOutStream(字节输出流),PipedReader(字符输入流),PipedWriter(字符输出流),同属节点流

PipedInputStream的一个实例要和PipedOutputStream的一个实例共同使用,共同完成管道的读取写入操作。主要用于线程操作。

 

字节/字符数组:ByteArrayInputStreamByteArrayOutputStreamCharArrayReaderCharArrayWriter是在内存中开辟了一个字节或字符数组,同属节点流

 

Buffered缓冲流:BufferedInputStreamBufferedOutputStreamBufferedReader,BufferedWriter,是带缓冲区的处理流,缓冲区的作用的主要目的是:避免每次和硬盘打交道,提高数据访问的效率。

 

转化流:InputStreamReader/OutputStreamWriter,把字节转化成字符,属于处理流.

 

数据流:DataInputStreamDataOutputStream,以最小的空间进行相关java基础类型数据的存储(int long char byte double等),属于处理流.

因为平时若是我们输出一个8个字节的long类型或4个字节的float类型,那怎么办呢?可以一个字节一个字节输出,也可以把转换成字符串输出,但是这样转换费时间,若是直接输出该多好啊,因此这个数据流就解决了我们输出数据类型的困难。数据流可以直接输出float类型或long类型,提高了数据读写的效率。

 

打印流:printStreamprintWriter,一般是打印到控制台,可以进行控制打印的地方,属于处理流.我们一齐看看PrintWriter其中一个构造函数,大家就懂了.

 

    public PrintWriter(Writer out,
                       boolean autoFlush) {
        super(out);
        this.out = out;
        this.autoFlush = autoFlush;
        lineSeparator = java.security.AccessController.doPrivileged(
            new sun.security.action.GetPropertyAction("line.separator"));
    }

    public PrintWriter(String fileName) throws FileNotFoundException {
        this(new BufferedWriter(new OutputStreamWriter(new FileOutputStream(fileName))),
             false);
    }

    public PrintWriter(OutputStream out, boolean autoFlush) {
        this(new BufferedWriter(new OutputStreamWriter(out)), autoFlush);

        // save print stream for error propagation
        if (out instanceof java.io.PrintStream) {
            psOut = (PrintStream) out;
        }
    }

 

 

 

对象流:ObjectInputStreamObjectOutputStream,把封装的对象直接输出,而不是一个个在转换成字符串再输出。

 

序列化流:SequenceInputStream

对象序列化:把对象直接转换成二进制,写入介质中。

使用对象流需要实现Serializable接口,否则会报错。而若用transient关键字修饰成员变量,不写入该成员变量,若是引用类型的成员变量为null,值类型的成员变量为0.

Java IO流分析整理

版权声明:本文为博主原创文章,未经博主允许不得转载。 转自:http://blog.csdn.net/yuebinghaoyuan/article/details/7388059 ...

Java IO流分析整理

Java中的流,可以从不同的角度进行分类。 按照数据流的方向不同可以分为:输入流和输出流。 按照处理数据单位不同可以分为:字节流和字符流。 按照实现功能不同可以分为:节点流和处理流。  第一个...

Java IO流分析整理

Java中的流,可以从不同的角度进行分类。 按照数据流的方向不同可以分为:输入流和输出流。 按照处理数据单位不同可以分为:字节流和字符流。 按照实现功能不同可以分为:节点流和处理流。...
  • wu_cai_
  • wu_cai_
  • 2016年06月06日 14:53
  • 162

Java IO流分析与整理

转载自:http://blog.csdn.net/yuebinghaoyuan/article/details/7388059 Java中的流,可以从不同的角度进行分类。 按照...

Java IO流分析整理

Java中的流,可以从不同的角度进行分类。 按照数据流的方向不同可以分为:输入流和输出流。 按照处理数据单位不同可以分为:字节流和字符流。 按照实现功能不同可以分为:节点流和处理流。...

Java IO流分析整理

转自:http://blog.csdn.net/yuebinghaoyuan/article/details/7388059 Java中的流,可以从不同的角度进行分类。 按照数据流的方...

Java IO流分析整理

Java中的流,可以从不同的角度进行分类。 按照数据流的方向不同可以分为:输入流和输出流。 按照处理数据单位不同可以分为:字节流和字符流。 按照实现功能不同可以分为:节点流和处理流。   输...

Java IO流分析整理

Java中的流,可以从不同的角度进行分类。 按照数据流的方向不同可以分为:输入流和输出流。 按照处理数据单位不同可以分为:字节流和字符流。 按照实现功能不同可以分为:节点流和处理流。...

Java IO流分析整理

Java中的流,可以从不同的角度进行分类。 按照数:输入流和输出流。 按照处理数据单位不同可以分为:字节流和字符流。 按照实现功能不同可以分为:节点流和处理流。 输出流:   输入流: 因此...

Java IO流分析整理

Java中的流,可以从不同的角度进行分类。 按照数据流的方向不同可以分为:输入流和输出流。 按照处理数据单位不同可以分为:字节流和字符流。 按照实现功能不同可以分为:节点流和处理流。...
  • cjjwwss
  • cjjwwss
  • 2014年07月23日 17:27
  • 288
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Java IO流分析整理
举报原因:
原因补充:

(最多只允许输入30个字)