inputstream中有几个 read() 方法和 outputstream中有几个 write() 方法。它们是一一对应的,而核心的是read()和write()方法。它们都没实现,所有本质调用是各自实现类实现的该两个方法。 read() 和 write() ,对应着系统的input和output,即系统的输出输入。
也是一个抽象类,即表示所有字节输入流实现类的基类。它的作用就是抽象地表示所有要输出到的目标,例如常见的fileoutstream、filteroutputstream等。它实现了java.io.closeable和java.io.flushable两个接口。其中空实现了flush方法,即拥有刷新缓存区字节数组作用。
那些输出目标呢?比如:
1) 字节数组(不代表string类,但可以转换) 2) 文件 3) 管道(多线程环境中的数据源) 等等
一样的,先看源码:
其中三个核心的write()方法,对应着三个inputstream的read()方法:
1. abstract void write(int b) 抽象方法
对应着,inputstream的read()方法,此方法依旧是抽象方法。因为子类必须实现此方法的一个实现。这就是输入流的关键方法。
二者,下面两个write方法中调用了此核心方法。
可见,核心的是read()和write()方法在传统的io是多么重要。
2. void write(byte b[]) 方法
将指定的byte数组的字节全部写入输出流。该效果实际上是由下一个write方法实现的,只是调用的额时候指定了长度:
3. void write(byte b[], int off, int len) 方法
将指定的byte数组中从偏移量off开始的len个字节写入输出流。代码详细流程解读如下:
a. 如果 <code>b</code> 为 <code>null</code>,则抛出 <code>nullpointerexception</code>。 b. 如果 <code>off</code> 为负,或 <code>len</code> 为负,或者 <code>off+len</code> 大于数组 <code>b</code> 的长度,则抛出 indexoutofboundsexception。 c. 将数组 <code>b</code> 中的某些字节按顺序写入输出流;元素 <code>b[off]</code> 是此操作写入的第一个字节,<code>b[off+len-1]</code> 是此操作写入的最后一个字节。
重要的事情说三遍:
outputstream 解读对照着 inputstream来看!注意 一个write对应一个read