IO流-概览

一、

   抽象类InputStream和OutputStream构成了了IO类的基础

   因为面向字节流的对象不便于处理Unicode形式储存的信息,所以从抽象类Reader和Writer中继承出专门用于处理Unicode字符的类构成了一个单独的层次结构

   这些类拥有的读入和写出操作都是基于两字节的Unicode码元的。

  

二、

   每个子类只需覆盖InputStream中read方法(读入一个字节)或者是OutputStream中write方法(向某个位置写出一个字节)

   read和write在执行时都将阻塞,直至字节确实被读入或写出,如果流不能被立即访问则该线程阻塞(可通过available方法判断可用于读入的字节数量来避免阻塞)

  

   API:

      java.io.InputStream:

      (1)abstract int read():从数据中读入一个字节,并返回该字节,在碰到流的尾时返回-1

      (2)int read(byte[] b):读入一个字节数组,返回实际读入的字节数,最多读入b.length个字节,在碰到流的尾时返回-1

      (3) int read(byte[] b, int off, int len):读入一个字节数组。这个read方法返回实际读入的字节数,或者在碰到流的结尾时返回-1

         参数:b 数据读入的数组

            off 第一个读入字节应该被放置的位置在b中的偏移量

            len 读入字节的最大数量

      (4) long skip(long n):在输入流中跳过n个字节,返回实际跳过的字节数(如果碰到流的结尾,则可能小于n) 。

      (5) int available():返回在不阻塞的情况下可用的字节数(阻塞意味着当前线程将失去它对资源的占用) 。

      (6) void close():关闭流

      (7) void mark(int readlimit):在输入流的当前位置打一个标记(并非所有的流都支持这个特性) 。如果从输入流中已经

         读入的字节多于readlimit个,则这个流允许忽略这个标记。

      (8)void reset():返回到最后的标记,随后对read的调用将重新读入这些字节。如果当前没有任何标记,

         则这个流不被重置。

      (9)boolean markSupported():如果这个流支持打标记,则返回true。

     

      java.io.OutputStream:

      (1) abstract void write(int n):写出一个字节的数据。

      (2) void write(byte[] b)

      (3) void write(byte[] b, int off, int len):写出所有字节或者某个范围的字节到数组b中

         参数:b 数据写出的数组

            off 第一个写出字节在b中的偏移量

            len 写出字节的最大数量

      (4) void close():清空并关闭输出流。

      (5)  void flush():清空输出流,也就是将所有缓冲的数据发送到目的地

     

三、流家族:

(一)字节流家族:

 

(二)Unicode文本流家族

 

四、组合流过滤器:

FileInputStream和FileOutputStream只能从文件中读入字节或者字节数组(不能读入数字类型),而DataInputStream只能读入数字类型(不能从文件中获取数据),那么可以组合这两个类从文件中读取数字:

FileInputStream fin = new FileInputStream(“test.txt”);

DataInputStream din = new DataInputStream(fin);

Double s = din.readDouble();

流在默认情况下是不进缓冲区的,那么我们可以这样组合:

DataInputStream din = new DataInputStream(

New BufferedInputStream(

New FileInputStream(“test.txt”)));(之所以把datainputsteam放在最后是为了使用DataInputStream的方法,并且希望它们能够使用带缓冲机制的read方法)

原文地址:https://www.cnblogs.com/orlion/p/4825754.html