小弟刚学java不久,有一个io的问题不太清楚,求教各位高手
FileInputStream的read方法,在使用的时候,如果采用了read(byte[] b,int off,int len)这个方法,也就是说将读取到的数据先放到一个数组中,然后再放到流中,这个过程是怎样工作的?是不是每次从磁盘上读取一个字节,然后写到byte数组中,当读取完长度为len的时候,再将数组写到输入流中???如果是这样,那么采用缓冲流BufferedInputStream和它又有什么区别呢?请教高手。
------解决方案--------------------
FileInputStream.read(byte[] b,int off,int len)方法,
是从IO中读取len个字节,放入b中,放入的起始位置是off。
这个方法是阻塞读的,仅当IO读取到末尾或者成功读取len个字节时,返回。
否则,读取过程中,当前线程会被阻塞,或者抛出IO异常。
BufferedInputStream的主要区别有两个:
1.读取时,会根据需要,先将IO的数据填充到缓冲区中,然后在复制给b数组。
FileInputStream.read(byte[] b,int off,int len)方法,直接将IO的数据放入b数组中。
2.支持 mark 和 reset 方法。
------解决方案--------------------
你看下InputStream的源码就知道呢。这个很容易弄到。好像安装jdk时,就会有一份在目录下的。
read(byte[] b,int off,int len)是会循环调用read()方法的:
- Java code
for (; j < paramInt2; j++) { i = read(); if (i == -1) { break; } if (paramArrayOfByte != null) paramArrayOfByte[(paramInt1 + j)] = (byte)i; }