Java中的流(2)字节流-InputStream和OutputStream
字节流的两个顶层类是抽象类:InputStream和OutputStream
1. OutputStream
| void write(int b) | 往流中写一个字节b |
| void write(byte b[]) | 往流中写一个字节数组b |
| void write(byte b[],int off,int len) | 把字节数组b中从下标off开始,长度为len的字节写入流中 |
| flush() | 刷空输出流,并输出所有被缓存的字节,由于某些流支持缓存功能,该方法将把缓存中所有内容强制输出到流中 |
| close() | 流操作完毕后必须关闭 |
2. InputStream
| int read() | 读取一个字节,返回值为所读得字节 |
| int read(byte b[]) | 读取多个字节,放置到字节数组b中,通常读取的字节数量为b的长度,返回值为实际独取的字节的数量 |
| int read(byte b[] ,int off,int len) | 读取len个字节,放置到以下标off开始字节数组b中,返回值为实际读取的字节的数量 |
| int available() | 返回值为流中尚未读取的字节的数量 |
| long skip(long n) | 读指针跳过n个字节不读,返回值为实际跳过的字节数量 |
| void mark(int readlimit) | 纪录当前指针的所在位置.readlimit表示读指针读出的readlimit个字节后 所标记的指针位置才实效 |
| void reset() | 把读指针重新指向用mark方法所记录的位置 |
| boolean markSupported() | 当前的流是否支持读指针的记录功能 |
| close() | 流操作完毕后必须关闭 |
3.下面简单介绍字节流的几个常用子类
抽象类InputStream和OutpurStream定义了实用的方法,其中最主要的是read()和write()。
这两个方法在InputStream和OutputStream中声明为抽象方法,由子流类overwrite实现。
|
字节流类 |
功能简单介绍 |
|
DataInputStream |
包含了读取Java标准数据类型的输入流 |
|
DataOutputStream |
包含了写Java标准数据类型的输出流 |
|
ByteArrayInputStream |
从字节数组读取的输入流 |
|
ByteArrayOutputStream |
写入字节数组的输出流 |
|
FileInputStream |
从文件读入的输入流 |
|
FileOutputStream |
写入文件的输出流 |
|
PrintStream |
包含最常见的Print()和Println()的输出流 |
|
PushbackInputStream |
返回一个字节到输入流,主要用于编译器的实现 |
|
PipedInputStream |
输出管道 |
|
PipedOutputStream |
输入管道 |
|
SequenceInputStream |
将n个输入流联合起来,一个接一个按一定顺序读取 |
|
RandomAccessFile |
随机访问文件 |
|
BufferInputStream |
缓冲输入流 |
|
BufferOutputStream |
缓冲输出流 |
|
FilterInputStream |
实现了InputStream Interface |
|
FilterOutputStream |
实现了OutputStream Interface |
|
InputStream |
抽象类,描述流的输入 |
|
OutputStream |
抽象类,描述流的输入 |


Java中的流(2)字节流-InputStream和OutputStream的更多相关文章
- Java:IO流之字节流InputStream、OutputStream详解
字节流: (抽象基类)InputStream类(读): (抽象基类)OutputStream类(写): InputStream: 构造方法摘要 InputStream() ...
- 理解Java中字符流与字节流
1. 什么是流 Java中的流是对字节序列的抽象,我们可以想象有一个水管,只不过现在流动在水管中的不再是水,而是字节序列.和水流一样,Java中的流也具有一个"流动的方向",通常可 ...
- 理解Java中字符流与字节流的区别(转)
1. 什么是流 Java中的流是对字节序列的抽象,我们可以想象有一个水管,只不过现在流动在水管中的不再是水,而是字节序列.和水流一样,Java中的流也具有一个“流动的方向”,通常可以从中读入一个字节序 ...
- 理解Java中字符流与字节流的区别
1. 什么是流 Java中的流是对字节序列的抽象,我们可以想象有一个水管,只不过现在流动在水管中的不再是水,而是字节序列.和水流一样,Java中的流也具有一个“流动的方向”,通常可以从中读入一个字节序 ...
- Java中字符流与字节流的区别
字符流处理的单元为2个字节的Unicode字符,分别操作字符.字符数组或字符串,而字节流处理单元为1个字节,操作字节和字节数组.所以字符流是由Java虚拟机将字节转化为2个字节的Unicode字符为单 ...
- Java I/O流-总结(InputStream,OutputStream,Reader,Writer)
Java流总结 一. 流的分类 • 按数据流动方向 – 输入流:只能从中读取字节数据,而不能向其写出数据 – 输出流:只能向其写入字节数据,而不能从中读取数据 • 按照流所处理的数据类型 – 字节流: ...
- java 笔记(4) —— java I/O 流、字节流、字符流
Java中使用流来处理程序的输入和输出操作,流是一个抽象的概念,封装了程序数据于输入输出设备交换的底层细节.JavaIO中又将流分为字节流和字符流,字节流主要用于处理诸如图像,音频视频等二进制格式数据 ...
- Java中IO流的总结
有关Java中IO流总结图 流分类 按方向分 输入流 输出流 按单位分 字节流 字符流 按功能分 节点流 处理流(过滤流) 其他 所有的流继承与这四类流:InputSteam.OutputStream ...
- java中有关流操作的类和接口
一.java操作l流有关的类和接口 1.File 文件类 2.RandomAccessFile 随机存储文件类 3.InputStream 字节输入流 4.OutputStream 字节输出流 5.R ...
随机推荐
- 全文检索(二)-基于lucene4.10的增删改查
今天 用lucene完毕了 一个简单的web应用.提取了早期编写的一个測试类. 首先简单介绍下lucene几个经常使用包; lucene 包的组成结构:对于外部应用来说索引模块(index)和检索模块 ...
- 鸡肋的JdbcRDD
今天准备将mysql的数据倒腾到RDD.非常早曾经就知道有一个JdbcRDD.就想着使用一下,结果发现却是鸡肋一个. 首先,看看JdbcRDD的定义: * An RDD tha ...
- Spring中注解
@Autowired :spring注解 @Resource :J2EE注解 @Transactional(rollbackFor=Exception.class):指定回滚 @RequestMapp ...
- html2canvas 导出包含滚动条的内容
import html2canvas from 'html2canvas'; exportPDF() { // 导出为 pdf let dom = document.querySelector('yo ...
- 设计模式-(13)访问者模式 (swift版)
一,概念 访问者模式,是行为型设计模式之一.访问者模式是一种将数据操作与数据结构分离的设计模式,它可以算是 23 中设计模式中最复杂的一个,但它的使用频率并不是很高,大多数情况下,你并不需要使用访问者 ...
- (MySQL里的数据)通过Sqoop Import HDFS 里 和 通过Sqoop Export HDFS 里的数据到(MySQL)(五)
下面我们结合 HDFS,介绍 Sqoop 从关系型数据库的导入和导出 一.MySQL里的数据通过Sqoop import HDFS 它的功能是将数据从关系型数据库导入 HDFS 中,其流程图如下所示. ...
- HDU1542 Atlantis —— 求矩形面积并 线段树 + 扫描线 + 离散化
题目链接:https://vjudge.net/problem/HDU-1542 There are several ancient Greek texts that contain descript ...
- Silverlight数据绑定之DataGrid
Silverlight数据绑定之DataGrid 时间:2011-08-03 01:59来源:网易博客 作者:Wilson. 点击:次 注:所有代码以C#为例 DataGrid绑定的数据对象: 1.D ...
- 【FFT初识】
FFT在用于解决多项式乘法A*B(A和B为多项式,形如a0+a1*x^1+a2*x^2....)的时候,通俗地解释就是: 原理:先根据各自的系数各自转化为对应的向量(O(nlogn)),然后向量相 ...
- 【HDU 2167】 Pebbles
[题目链接] 点击打开链接 [算法] 状压DP 先搜出一行符合的情况,然后,f[i][j]表示第i行,状态为j,能够取得的最大值,DP即可 [代码] #include<bits/stdc++.h ...