源代码均以JDK1.8作为參考

前言:

InputStream实现了两个接口Closeable和AutoCloseable:



Closeable:JDK1.5中引入,Closeable接口中仅仅有一个close()方法的定义:

public void close() throws IOException;

实现了Closeable接口的类的对象能够被关闭,流类都实现了该接口,以达到关闭流的目的。

AutoCloseable:JDK1.7中引入,为JDK1.7中引入的带资源的try语句提供了支持。try能够自己主动关闭资源。

AutoCloseable接口亦仅仅定义了一个close()方法的定义:

void close() throws Exception;

仅仅有实现了AutoCloseable接口的类的对象才干够使用带资源的try语句进行管理。在JDK1.7中Closeable继承了AutoCloseable接口,所以IO包下的流类都能够使用带资源的try语句进行管理。

源代码分析:

InputStream是相对于Java本身来说的,从其它途径向内读取数据,所以叫输入流。

InputStream是一个抽象类。是java.io流字节流的基类。

InputStream中定义了一系列方法。

主要方法:

1.public abstract int read():

从输入流中读取数据的下一个字节。返回 0 到 255 范围内的 int 字节值。假设由于已经到达流末尾而没有可用的字节。则返回值 -1。

在输入数据可用、检測到流末尾或者抛出异常前。此方法一直堵塞。

子类必须提供此方法的一个实现。

2.public int read(byte b[]):

从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。以整数形式返回实际读取的字节数。

3.public int read(byte b[], int off, int len):

将输入流中最多 len 个数据字节读入 byte(从byte数组的off索引開始读入) 数组。

尝试读取 len 个字节,但读取的字节也可能小于该值。

以整数形式返回实际读取的字节数。

注:对于InputStream中的2和3方法,事实上现都是依赖1方法来实现的,通过1方法获取单个字节,读入2和3中指定的缓冲数组中。

4. public long skip(long n):

在输入流中跳过指定字节数的读取。跳过的字节数为n,可是InputStream定义了skip的最大长度MAX_SKIP_BUFFER_SIZE=2048,n超过这个值。将仅仅跳过MAX_SKIP_BUFFER_SIZE个字节的读取。源代码例如以下:

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;
}

相同基于read系列重载方法实现,原理就是直接讲指定个数的字节读取。可是不进行保留,以完毕skip操作。

5. public int available():

返回该InputStream在不被堵塞的情况下下一次能够读到的数据长度。

6. public void close():

关闭InputStream流

7. public synchronized void mark(int readlimit):

标记InputStream流中的某一个位置,由其子类进行详细实现。

8. public synchronized void reset():

将此流又一次定位到最后一次对此输入流调用 mark 方法时的位置。

9. public boolean markSupported():

检查此流是否支持详细实现了public synchronized void mark(int readlimit)方法。

总: InputStream在一定程度上对输入流做了一个抽象。定义了输入流的基本职责,可是并不提供详细的实现。仅仅是做简单的约束。并不是强制重写,由于InputStream是abstract修饰的,所以其并不具有实例化的能力,要全然借助于其子类实现对于流的各种操作。

Java IO(二) 之 InputStream的更多相关文章

  1. 图解 Java IO : 二、FilenameFilter源码

    Writer      :BYSocket(泥沙砖瓦浆木匠) 微         博:BYSocket 豆         瓣:BYSocket FaceBook:BYSocket Twitter   ...

  2. Java IO(二)

    字节流 字符流: FileReader FileWriter BufferedReader BufferedWriter 字节流: FileInputStream FileOutputStream B ...

  3. java IO(二):字节流

    */ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...

  4. 系统学习 Java IO (二)----IO 异常处理

    目录:系统学习 Java IO---- 目录,概览 我们使用流后,需要正确关闭 Streams 和 Readers / Writers . 这是通过调用 close() 方法完成的,看看下面这段代码: ...

  5. Java IO:为什么InputStream只能读一次

    http://zhangbo-peipei-163-com.iteye.com/blog/2021879 InputStream的接口规范就是这么设计的. /** * Reads the next b ...

  6. Java IO(二)--RandomAccessFile基本使用

    RandomAccessFile: 翻译过来就是任意修改文件,可以从文件的任意位置进行修改,迅雷的下载就是通过多个线程同时读取下载文件.例如,把一个文件分为四 部分,四个线程同时下载,最后进行内容拼接 ...

  7. ava.io.InputStream & java.io.FileInputStream

    java.io.InputStream & java.io.FileInputStream java.io.InputStream,这个抽象类是表示字节输入流的超类,这个抽象类的共性的方法有: ...

  8. Java IO流(二)

    目录 字节缓冲流 概述 BufferedOutputStream类 继承父类的共性成员方法 构造方法 BufferedInputStream类 继承自父类的方法: 构造方法 文件复制练习(增强版 使用 ...

  9. Java IO学习笔记(一)

    一.概念 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.在两设备间的传输的数据称为流,流的本质是数据传输,根据数据传输特性将流抽象为各种类,以进行数据操作. 二.流分类 数据类型 ...

随机推荐

  1. Unity 摄像头竖屏预览显示的问题

    Unity可以通过WebCamTexture打开摄像头,通过 cameraRawImage.texture = camTexture; 将贴图给RawImage,但是WebCamTexture只能设置 ...

  2. HDU 4311 Contest 2

    求的是曼哈顿距离.可以把X,Y的距离分开来求.其中,求X.Y的距离可以通过排序后递推的方式求出值的. #include <iostream> #include <algorithm& ...

  3. System.arraycopy用法

    System.arraycopy用法 注意长度的设置: public class ArrCopy { public static void main(String[] args) { int [] s ...

  4. Docker 命令行和后台參数

    Docker官方为了让用户高速了解Docker,提供了一个交互式教程,旨在帮助用户掌握Docker命令行的用法. Docker 命令行 以下对Docker的命令清单进行简单的介绍,具体内容在兴许章节具 ...

  5. linux 命令 xxd

    xxd,能够查看linux下文件的二进制表示.man一下xxd.能够得到下面信息 NAME        xxd - make a hexdump or do the reverse. SYNOPSI ...

  6. c++ STL unique , unique_copy函数

    一.unique函数 类属性算法unique的作用是从输入序列中"删除"全部相邻的反复元素. 该算法删除相邻的反复元素.然后又一次排列输入范围内的元素,而且返回一个迭代器(容器的长 ...

  7. vijos-1382 寻找主人

    题意: 给出两个同样长度的数字串: 求两个串是否本质同样.同样则输出最小表示. 长度L似乎给的不正确,大概是2000000左右吧: 题解: 最小表示法裸题.证明正确性啥的详见论文吧: 这东西大体的思路 ...

  8. web security

    brute force cracking   暴力破解 Brute force (also known as brute force cracking) is a trial and error me ...

  9. swoole-tcp-server

    swoole-tcp-server 标签(空格分隔): php,linux 执行程序 php swoole_server.php 查看端口:netstat -antpl 连接服务器:telnet ip ...

  10. mysql实战45讲读书笔记(二) 一条SQL更新语句是如何执行的 极客时间

    前面我们系统了解了一个查询语句的执行流程,并介绍了执行过程中涉及的处理模块.相信你还记得,一条查询语句的执行过程一般是经过连接器.分析器.优化器.执行器等功能模块,最后到达存储引擎. 那么,一条更新语 ...