[五] JavaIO之InputStream OutputStream简介 方法列表说明

InputStream 和 OutputStream 对于字节流的输入和输出

是作为协议的存在

所以有必要了解下这两个类提供出来的基本约定

这两个类是抽象类,而且基本上没什么实现,都是依赖于子类具体的去实现

但是他是对于其子类 协议纲领一般的存在

了解清楚每一个方法含义,对于后续具体的子类将会有非常大的帮助

基本含义

InputStream 所有字节输入流的 超类 他是一个抽象类
OutputStream 所有字节输出流的 超类 他是一个抽象类

方法列表

InputStream  包含了读取方法以及辅助方法

OutputStream包含了写入方法以及辅助方法

方法对照


read()

read(byte[])

read(byte[], int, int)


write(byte[])

write(byte[], int, int)

write(int)

close close
  flush()

available()

mark(int)

markSupported()

reset()

skip(long)

方法详解

read

read()  从输入流中读取数据的下一个字节。返回 0 到 255 范围内的 int 字节值
如果因为已经到达流末尾而没有可用的字节,则返回值 -1
方法将会一直阻塞,直到数据可用,检测到流的末尾或者抛出异常
无参数的read() 是抽象方法,由实现类提供实现

三个read方法实际上根本方法都是read()方法

其他两个方法为拓展功能,逻辑便捷方法

无参数的read()返回的数据为读取到的字节值
而有参数的则是读取到字节数组中,所以返回值为读取到的个数
read方法关键点
要么就是直接返回读取的字节
要么就是将读取到的字节放入字节数组中,字节数组是你传递进去的

write


write(int b)

将指定的字节写入此输出流
write 的常规协定是:向输出流写入一个字节, 要写入的字节是参数 b 的八个低位   b 的 24 个高位将被忽略
说白了就是写入的是byte虽然参数是int


write(byte[] b)

将 b.length 个字节从指定的 byte 数组写入此输出流

write(b) 的常规协定是:应该与调用 write(b, 0, b.length) 的效果完全相同


write(byte[] b,int off,int len)

将指定 byte 数组中从偏移量 off 开始的 len 个字节写入此输出流

write(b, off, len) 的常规协定是:将数组 b 中的某些字节按顺序写入输出流;

元素 b[off] 是此操作写入的第一个字节,b[off+len-1] 是此操作写入的最后一个字节

类似read的调用形式
直接写入指定字节的write(int b)  方法是根本
其他的是拓展功能
read()  与write(int b) 是根本的读取一个字节或者写入一个字节的方法
其余形式是针对传入字节数组作为参数,以及指定字节数组的偏移量时的一些拓展功能
一旦传递了字节数组作为参数
read将会读取数据到字节数组
write将会将字节数组的数据写入

close

都需要关闭流,所以都有close方法
都是关闭流并释放与此流有关的系统资源
都可能抛出IOException
在InputStream和OutputStream中,两个close方法都是空方法

flush

flush的含义为刷新,在写入数据时使用
所以,只有输出流拥有flush方法
之所以需要刷新,是因为有的输出流的写方法实现,可能已经缓冲了以前写入的任何字节
那么,这个方法用于提供能够立即将数据写入到磁盘的功能
不过,只是立即请求操作系统进行处理,而不保证这些字节实际已经写入到物理设备,比如磁盘

下面几个为InputStream独有

public int available()  throws IOException

返回此输入流下一个方法调用可以不受阻塞地从此输入流读取(或跳过)的估计字节数

这句话有些绕口,直白的说就是:

在方法调用前,可以获取到这个流中可用的字节数目

假设说有N个字节可以使用,显然你应该很可能读取到N个字节,或者能够跳过N个字节

一次读取或跳过此估计数个字节不会受阻塞

注意:
这个数目是一个预估的数量
实际的读取或者跳过的字节数可能小于这个数
InputStream中的这个方法总是返回0 
所以这个方法能否使用依赖于子类的实现

public long skip(long n) throws IOException
返回的是实际跳过的字节数
在内部创建一个 byte 数组,然后重复将字节读入其中,直到读够 n 个字节或已到达流末尾为止

reset()

mark(int)

markSupported() 

三个方法是对于同一个功能点的不同方法  ,可以解决重复读的问题

mark(int)用来在此输入流中做标记,标记当前位置  打一个书签
markSupported()   测试此输入流是否支持 mark 和 reset 方法
reset()  将此流重新定位到最后一次对此输入流调用 mark 方法时的位置   回到书签

看下类中的默认代码可以发现:

默认情况下mark什么都不做

markSupported直接返回false

reset方法的调用会抛出异常

mark的参数用于告知输入流在标记位置失效之前允许读取的字节数
标记已关闭的流对其无效
说起来很迷惑,用起来却很简单
比如
xxxStream.mark(50);//表明系统至少应该缓冲50以上个数据,以保证可以回来重新读取
xxxStream.read();
.....
xxxStream.read();

xxxStream.reset();//reset之后,读取到的数据将会和刚才调用mark 方法后read的数据是相同的

xxxStream.read();

.....

xxxStream.read();

如果方法 markSupported 返回 true,那么输入流总是在调用 mark 之后记录所有读取的字节
并时刻准备在调用方法 reset 时(无论何时),再次提供这些相同的字节
但是,如果在调用 reset 之前可以从流中读取多于 readlimit 的字节,则不需要该流记录任何数据

原文地址:https://www.cnblogs.com/noteless/p/9618521.html

时间: 2024-10-28 20:41:22

[五] JavaIO之InputStream OutputStream简介 方法列表说明的相关文章

InputStream & OutputStream 使用方法以及注意事项

1 /* 2 * To change this license header, choose License Headers in Project Properties. 3 * To change this template file, choose Tools | Templates 4 * and open the template in the editor. 5 */ 6 package InputStream; 7 8 import java.io.BufferedInputStre

InputStream && OutputStream

InputStream && OutputStream 介绍 IO流操作中非常重要的一组接口(其实是抽象类)是InputStream和OutputStream. InputStream字节输入流其最核心的一个方法是read()方法 OutputStream字节输出流其最核心的一个方法是write()方法 所有字节输入输都要实现read方法,所有字节输出流都要实现write()方法. 字节流可以操作任意类型的文件(二进制或文本文件) 首先了解几个概念: 01机器码:只有机器才能识别0101串

jQuery学习笔记--JqGrid相关操作 方法列表(上)

1.获得当前列表行数:$("#gridid").getGridParam("reccount"); 2.获取选中行数据(json):$("#gridid").jqGrid('getRowData', id); 3.刷新列表:$(refreshSelector).jqGrid('setGridParam', { url: ''), postData: ''}).trigger('reloadGrid'); 4.选中行:$("#jqGrid

玩转web之json(五)---将表单通过serialize()方法获取的值转成json

form表单有一个serialize()方法,可以序列化表单的值,但是jquery提供的这个方法会把数据序列化为类似下面的形式: a=1&b=2&c=3&d=4 jquery并没有提供将表单数据序列化为json的方法,所以需要我们自己封装一下,下面给出代码和测试样例,先写一个js文件: $.ajaxSetup({ contentType: "application/x-www-form-urlencoded; charset=utf-8" }); var Dat

C#获取当前堆栈的各调用方法列表

在使用.NET编写的代码在debug时很容易进行排查和定位问题,一旦项目上线并出现问题的话那么只能依靠系统日志来进行问题排查和定位,但当项目复杂时,即各种方法间相互调用将导致要获取具体的出错方法或调用者将是一件不那么容易的事(因为没有PDB文件) 还好.NET提供了一系列系统组件来帮助我们获取项目堆栈信息用于定位和排查,以下代码将返回出错堆栈调用的各上一级方法,直到最终的调用者方法 /********************************************************

JqGrid相关操作备忘 方法列表

JqGrid相关操作备忘 方法列表 1.获得当前列表行数:$("#gridid").getGridParam("reccount"); 2.获取选中行数据(json):$("#gridid").jqGrid('getRowData', id); 3.刷新列表:$(refreshSelector).jqGrid('setGridParam', { url: ''), postData: ''}).trigger('reloadGrid'); 4.选

方法列表说明

方法列表说明 关于static const JNINativeMethod method_table[]方法列表的原型如下: [cpp] view plaincopy typedef struct { const char* name; const char* signature; void* fnPtr; } JNINativeMethod; Andoird 中使用了一种不同传统Java JNI的方式来定义其native的函数.其中很重要的区别是Andorid使用了一种Java 和 C 函数的

Android -- 小问题 InputStream的read方法读取字节不完全的问题

关于InputStream.read(byte[] b)和InputStream.read(byte[] b,int off,int len)这两个方法都是用来从流里读取多个字节的,有经验的程序员就会发现,这两个方法经常 读取不到自己想要读取的个数的字节.比如第一个方法,程序员往往希望程序能读取到b.length个字节,而实际情况是,系统往往读取不了这么多.仔细阅读Java的API说明就发现了,这个方法 并不保证能读取这么多个字节,它只能保证最多读取这么多个字节(最少1个).因此,如果要让程序读

python之ActionChains方法列表

使用方法: 方法列表: click(on_element=None) --单击鼠标左键 click_and_hold(on_element=None) --点击鼠标左键,不松开 context_click(on_element=None) --点击鼠标右键 double_click(on_element=None) --双击鼠标左键 drag_and_drop(source, target) --拖拽到某个元素然后松开 drag_and_drop_by_offset(source, xoffse