Java IO之InputStream源码分析

01.InputStream介绍

在这里插入图片描述
InputStream抽象类是表示输入字节流的所有类的超类。
所有继承InputStream的类必须重写read()方法。
实现了AutoCloseable接口,可以使用try_with_resource自动关闭流。

02.源码分析

public abstract class InputStream implements Closeable ;

当使用skip方法时,能跳过的最大缓冲区大小。
private static final int MAX_SKIP_BUFFER_SIZE = 2048;

从输入流读取数据的下一个字节。 值字节被返回作为int范围0至255 。 如果没有字节可用,因为已经到达流的末尾,则返回值-1 。 该方法阻塞直到输入数据可用,检测到流的结尾,或抛出异常。
public abstract int read() throws IOException;

从输入流读取一些字节数,并将它们存储到缓冲区b 。 实际读取的字节数作为整数返回。 该方法阻塞直到输入数据可用,检测到文件结束或抛出异常。

如果b的长度为零,则不会读取字节并返回0 ; 否则,尝试读取至少一个字节。 如果没有字节可用,因为流在文件末尾,则返回值-1 ; 否则,读取至少一个字节并存储到b 。
public int read(byte b[]) throws IOException {
        return read(b, 0, b.length);
    }

从输入流读取len字节的数据到一个字节数组。 尝试读取多达len个字节,但可以读取较小的数字(流字节数小于len)。 实际读取的字节数作为整数返回。
底层还是调用read方法一个一个读。
public int read(byte b[], int off, int len) throws IOException {
        if (b == null) {
            throw new NullPointerException();
        } else if (off < 0 || len < 0 || len > b.length - off) {   比较是否可以容纳
            throw new IndexOutOfBoundsException();
        } else if (len == 0) {
            return 0;
        }

        int c = read();
        if (c == -1) {
            return -1;  判断流中是否有字节数据,流在文件末尾
        }
        b[off] = (byte)c;

        int i = 1;
        try {
            for (; i < len ; i++) {
                c = read();
                if (c == -1) {
                    break;
                }
                b[off + i] = (byte)c;
            }
        } catch (IOException ee) {
        }
        return i;
    }

n - 要跳过的字节数。
返回实际跳过的字节数。
跳过并丢弃来自此输入流的n字节数据。
public long skip(long n) throws IOException {

        long remaining = n;
        int nr;

        if (n <= 0) {
            return 0;
        }

        int size = (int)Math.min(MAX_SKIP_BUFFER_SIZE, remaining);
        byte[] skipBuffer = new byte[size];
        while (remaining > 0) {
            nr = read(skipBuffer, 0, (int)Math.min(size, remaining));
            if (nr < 0) {
                break;
            }
            remaining -= nr;
        }

        return n - remaining;
    }

返回从该输入流中可以读取(或跳过)的字节数的估计值,而不会被下一次调用此输入流的方法阻塞
    public int available() throws IOException {
        return 0;
    }

标记此输入流中的当前位置。 对reset方法的后续调用会将该流重新定位在最后一个标记的位置,以便后续读取重新读取相同的字节。
public synchronized void mark(int readlimit) {};

将此流重新定位到上次在此输入流上调用mark方法时的位置。
 public synchronized void reset() throws IOException {
        throw new IOException("mark/reset not supported");
    }

测试这个输入流是否支持mark和reset方法。 是否mark和reset是特定输入流实例的不变属性。 该markSupported的方法InputStream返回false 
public boolean markSupported() {
        return false;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值