public interface ImageInputStream
供 ImageReader
使用的可查找输入流接口。各种输入源(如 InputStream
、File
以及将来的快速 I/O 源)都可以通过此接口的恰当实现进行“包装”,供 Image I/O API 使用。
ImageInputStreamImpl
,
FileImageInputStream
,
FileCacheImageInputStream
,
MemoryCacheImageInputStream
方法摘要 | |
---|---|
void |
close() 关闭流。 |
void |
flush() 丢弃当前流位置之前的流初始部分。 |
void |
flushBefore(long pos) 丢弃所指示位置之前的流初始部分。 |
int |
getBitOffset() 以整数的形式返回当前位偏移量,该整数在 0 到 7 之间(包含两者)。 |
ByteOrder |
getByteOrder() 以 java.nio.ByteOrder 枚举实例的形式返回从此流中读取数据值时所使用的字节顺序。 |
long |
getFlushedPosition() 返回流中可以执行查找的最早位置。 |
long |
getStreamPosition() 返回流的当前字节位置。 |
boolean |
isCached() 如果此 ImageInputStream 本身为了允许逆向查找而缓存了数据,则返回 true 。 |
boolean |
isCachedFile() 如果此 ImageInputStream 本身为了允许逆向查找而缓存了数据,并且将其保存在临时文件中,则返回 true 。 |
boolean |
isCachedMemory() 如果此 ImageInputStream 本身为了允许逆向查找而缓存了数据,并将其保存在主存中,则返回 true 。 |
long |
length() 返回流的总长度(如果已知)。 |
void |
mark() 标记流中某个位置,供后续调用 reset 时返回。 |
int |
read() 从流中读取单个字节,并以整数(0 到 255 之间)形式返回该字节。 |
int |
read(byte[] b) 从流中读取至多 b.length 个字节,并将其存储到 b 中(从索引 0 开始)。 |
int |
read(byte[] b, int off, int len) 从流中读取至多 len 个字节,并将其存储到 b 中(从索引 off 开始)。 |
int |
readBit() 从流中读取单个字节,并以 int (0 或 1 )的形式返回该字节。 |
long |
readBits(int numBits) 从流中读取位串 (bitstring) 并以 long 的形式返回,使第一个读取的位成为输出的最高有效位。 |
boolean |
readBoolean() 从流中读取一个字节,如果其不为 0,则返回 boolean 值 true ;如果为 0,则返回 false 。 |
byte |
readByte() 从流中读取一个字节,并以 byte 值的形式返回该字节。 |
void |
readBytes(IIOByteBuffer buf, int len) 从流中读取至多 len 个字节,并修改提供的 IIOByteBuffer 以指示可以找到数据的 byte 数组、偏移量和长度。 |
char |
readChar() 与 readUnsignedShort 等效,唯一的不同在于它的结果使用 char 数据类型返回。 |
double |
readDouble() 从流中读取 8 个字节,根据当前字节顺序将其连接(概念上),然后以 double 值的形式返回结果。 |
float |
readFloat() 从流中读取 4 个字节,根据当前字节顺序将其连接(概念上),然后以 float 值的形式返回结果。 |
void |
readFully(byte[] b) 从流中读取 b.length 个字节,并将其存储到 b 中(从索引 0 开始)。 |
void |
readFully(byte[] b, int off, int len) 从流中读取 len 个字节,并将其存储到 b 中(从索引 off 开始)。 |
void |
readFully(char[] c, int off, int len) 根据当前字节顺序从流中读取 len 个 char(无符号 16 位整数),并将其存储到 c 中(从索引 off 开始)。 |
void |
readFully(double[] d, int off, int len) 根据当前字节顺序从流中读取 len 个 double(64 位 IEEE 双精度浮点值),并将其存储到 d 中(从索引 off 开始)。 |
void |
readFully(float[] f, int off, int len) 根据当前字节顺序从流中读取 len 个 float(32 位 IEEE 单精度浮点值),并将其存储到 f 中(从索引 off 开始)。 |
void |
readFully(int[] i, int off, int len) 根据当前字节顺序从流中读取 len 个 int(有符号 32 位整数),并将其存储到 i 中(从索引 off 开始)。 |
void |
readFully(long[] l, int off, int len) 根据当前字节顺序从流中读取 len 个 long(有符号 64 位整数),并将其存储到 l 中(从索引 off 开始)。 |
void |
readFully(short[] s, int off, int len) 根据当前字节顺序从流中读取 len 个 short(有符号 16 位整数),并将其存储到 s 中(从索引 off 开始)。 |
int |
readInt() 从流中读取 4 个字节,根据当前字节顺序将其连接(概念上),然后以 int 值的形式返回结果。 |
String |
readLine() 从输入流中读取文本的下一行。 |
long |
readLong() 从流中读取 8 个字节,根据当前字节顺序将其连接(概念上),然后以 long 值的形式返回结果。 |
short |
readShort() 从流中读取两个字节,根据当前字节顺序将其连接(概念上),然后以 short 值的形式返回结果。 |
int |
readUnsignedByte() 从流中读取一个字节,将其转换为 int(概念上),使用 0xff 屏蔽以便去掉所有符号扩展位,然后以 byte 值的形式返回。 |
long |
readUnsignedInt() 从流中读取 4 个字节,根据当前字节顺序将其连接(概念上),将得到的值转换为 long,使用 0xffffffffL 屏蔽以便去掉所有符号扩展位,然后以无符号 long 值的形式返回结果。 |
int |
readUnsignedShort() 从流中读取两个字节,根据当前字节顺序将其连接(概念上),将得到的值转换为 int ,使用 0xffff 屏蔽以便去掉所有符号扩展位,然后以无符号 int 值的形式返回结果。 |
String |
readUTF() 读入一个已使用 UTF-8 修改版格式编码的字符串。 |
void |
reset() 返回在最近一次非匹配地调用 mark 时指向上一个位置(包括位偏移量)的流指针。 |
void |
seek(long pos) 将当前流位置设置为所需的位置。 |
void |
setBitOffset(int bitOffset) 将位偏移量设置为 0 到 7 之间(包含两者)的整数。 |
void |
setByteOrder(ByteOrder byteOrder) 设置希望以后从此流中读取数据值时使用的字节顺序。 |
int |
skipBytes(int n) 将流位置向前移动给定的字节数。 |
long |
skipBytes(long n) 将流位置向前移动给定的字节数。 |
方法详细信息 |
---|
void setByteOrder(ByteOrder byteOrder)
枚举类 java.nio.ByteOrder
用于指定字节顺序。值 ByteOrder.BIG_ENDIAN
指定所谓的 big-endian 或网络字节顺序,该顺序中高位字节在前。Motorola 和 Sparc 处理器用此格式存储数据,而 Intel 处理器使用与之相反的 ByteOrder.LITTLE_ENDIAN
顺序存储数据。
字节顺序对 readBits
方法返回的结果(或 ImageOutputStream.writeBits
写入的值)没有任何影响。
byteOrder
-
ByteOrder.BIG_ENDIAN
或
java.nio.ByteOrder.LITTLE_ENDIAN
,指示以后读取时是使用网络顺序还是使用与之相反的顺序。
ByteOrder
,
getByteOrder()
,
readBits(int)
ByteOrder getByteOrder()
java.nio.ByteOrder
枚举实例的形式返回从此流中读取数据值时所使用的字节顺序。
ByteOrder.BIG_ENDIAN
或
ByteOrder.LITTLE_ENDIAN
,指示要使用的字节顺序。
ByteOrder
,
setByteOrder(java.nio.ByteOrder)
int read() throws IOException
在进行读取前,流中的位偏移量被重置为 0。
IOException
- 如果发生 I/O 错误。
int read(byte[] b) throws IOException
b.length
个字节,并将其存储到
b
中(从索引 0 开始)。返回读取的字节数。如果因到达流末尾而无法读取任何字节,则返回 -1。
在进行读取前,流中的位偏移量被重置为 0。
b
- 用来接收写入的 byte 数组。
-1
,指示 EOF。
NullPointerException
- 如果
b
为
null
。
IOException
- 如果发生 I/O 错误。
int read(byte[] b, int off, int len) throws IOException
len
个字节,并将其存储到
b
中(从索引
off
开始)。返回读取的字节数。如果因到达流末尾而无法读取任何字节,则返回
-1
。
在进行读取前,流中的位偏移量被重置为 0。
b
- 用来接收写入的 byte 数组。
off
- 向
b
进行写入的开始位置。
len
- 要读取的最大
byte
数。
-1
,指示 EOF。
NullPointerException
- 如果
b
为
null
。
IndexOutOfBoundsException
- 如果
off
为负、
len
为负或者
off + len
大于
b.length
。
IOException
- 如果发生 I/O 错误。
void readBytes(IIOByteBuffer buf, int len) throws IOException
len
个字节,并修改提供的
IIOByteBuffer
以指示可以找到数据的 byte 数组、偏移量和长度。调用者不应该试图修改
IIOByteBuffer
中找到的数据。
在进行读取前,流中的位偏移量被重置为 0。
buf
- 要修改的 IIOByteBuffer 对象。
len
- 要读取的最大
byte
数。
IndexOutOfBoundsException
- 如果
len
为负。
NullPointerException
- 如果
buf
为
null
。
IOException
- 如果发生 I/O 错误。
boolean readBoolean() throws IOException
boolean
值
true
;如果为 0,则返回
false
。
在进行读取前,流中的位偏移量被重置为 0。
DataInput
中的
readBoolean
EOFException
- 如果到达流末尾。
IOException
- 如果发生 I/O 错误。
byte readByte() throws IOException
byte
值的形式返回该字节。
0x00
到
0x7f
之间的字节值表示
0
到
127
之间的整数值。
0x80
到
0xff
之间的字节值表示
-128
到
-1
之间的负整数值。
在进行读取前,流中的位偏移量被重置为 0。
EOFException
- 如果到达流末尾。
IOException
- 如果发生 I/O 错误。
int readUnsignedByte() throws IOException
0xff
屏蔽以便去掉所有符号扩展位,然后以
byte
值的形式返回。
于是,0x00
到 0x7f
之间的字节值便作为 0
到 127
之间的整数值返回。0x80
到 0xff
之间的字节值通常表示为负的 byte
值,它们将被映射成 128
到 255
之间的正整数。
在进行读取前,流中的位偏移量被重置为 0。
DataInput
中的
readUnsignedByte
EOFException
- 如果到达流末尾。
IOException
- 如果发生 I/O 错误。
short readShort() throws IOException
short
值的形式返回结果。
在进行读取前,流中的位偏移量被重置为 0。
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
getByteOrder()
int readUnsignedShort() throws IOException
int
,使用
0xffff
屏蔽以便去掉所有符号扩展位,然后以无符号
int
值的形式返回结果。
在进行读取前,流中的位偏移量被重置为 0。
DataInput
中的
readUnsignedShort
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
getByteOrder()
char readChar() throws IOException
readUnsignedShort
等效,唯一的不同在于它的结果使用
char
数据类型返回。
在进行读取前,流中的位偏移量被重置为 0。
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
readUnsignedShort()
int readInt() throws IOException
int
值的形式返回结果。
忽略流中的位偏移量,将其视为 0。
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
getByteOrder()
long readUnsignedInt() throws IOException
0xffffffffL
屏蔽以便去掉所有符号扩展位,然后以无符号
long
值的形式返回结果。
在进行读取前,流中的位偏移量被重置为 0。
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
getByteOrder()
long readLong() throws IOException
long
值的形式返回结果。
在进行读取前,流中的位偏移量被重置为 0。
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
getByteOrder()
float readFloat() throws IOException
float
值的形式返回结果。
在进行读取前,流中的位偏移量被重置为 0。
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
getByteOrder()
double readDouble() throws IOException
double
值的形式返回结果。
在进行读取前,流中的位偏移量被重置为 0。
DataInput
中的
readDouble
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
getByteOrder()
String readLine() throws IOException
String
形式返回读取的字符。注意,因为此方法处理字符,所以它不支持整个 Unicode 字符集的输入。
如果在一个字节都没有读取的时候就遇到文件结束标记,则返回 null
。否则,通过左侧补 0 将读取的每个字节转换成 char
类型的值。如果遇到字符 '\n'
,则丢弃它并且停止读取。如果遇到字符 '\r'
,则丢弃它;如果它后面的那个字节转变成字符 '\n'
,则同样丢弃它,并且停止读取。如果在遇到字符 '\n'
和 '\r'
之一前遇到文件结束标记,则停止读取。一旦已停止读取,则返回一个 String
,它按顺序包含所有已读取且未丢弃的字符。注意,此字符串中的每个字符的值都将小于 \u0100
(即 (char)256
)的值。
在进行读取前,流中的位偏移量被重置为 0。
IOException
- 如果发生 I/O 错误。
String readUTF() throws IOException
readUTF
的常规协定是:该方法读取使用 UTF-8 修改版格式编码的 Unicode 字符串的表示形式;然后以
String
的形式返回此字符串。
首先,读取两个字节并按 readUnsignedShort
方法的方式使用这两个字节构造一个无符号 16 位整数,使用的是网络字节顺序(无论当前设置的是哪种字节顺序)。该整数值被称为 UTF 长度,它指定要读取的额外字节数。然后成组地将这些字节转换为字符。每组的长度根据该组第一个字节的值计算。紧跟在某个组后面的字节(如果有)是下一组的第一个字节。
如果组的第一个字节与位模式 0xxxxxxx
(其中 x
表示“可能为 0
或 1
”)匹配,则该组只有这一个字节。该字节被左侧补 0,转换成一个字符。
如果组的第一个字节与位模式 110xxxxx
匹配,则该组只由字节 a
和另一个字节 b
组成。如果没有字节 b
(因为字节 a
是要读取的最后一个字节),或者字节 b
与位模式 10xxxxxx
不匹配,则抛出 UTFDataFormatException
。否则,将该组转换成字符:
(char)(((a& 0x1F) << 6) | (b & 0x3F))
如果组的第一个字节与位模式
1110xxxx
匹配,则该组由字节
a
和另外两个字节
b
和
c
组成。如果没有字节
c
(因为字节
a
是要读取的最后两个字节之一),或者字节
b
或字节
c
与位模式
10xxxxxx
不匹配,则抛出
UTFDataFormatException
。否则,将该组转换成字符:
(char)(((a & 0x0F) << 12) | ((b & 0x3F) << 6) | (c & 0x3F))
如果组的第一个字节与模式
1111xxxx
或模式
10xxxxxx
匹配,则抛出
UTFDataFormatException
。
如果在整个执行过程中的任意时间遇到文件结束标记,则抛出 EOFException
。
在通过此过程将每个组转换成字符后,按照从输入流中读取相应组的顺序,将这些字符收集在一起,形成一个 String
,然后该字符串将被返回。
忽略当前设置的字节顺序。
在进行读取前,流中的位偏移量被重置为 0。
注:在使用标准 UTF-8 图像格式的实现中不应该使用此方法,因为此处使用的 UTF-8 修改版与标准 UTF-8 不兼容。
EOFException
- 如果此流在读取所有字节之前到达末尾。
UTFDataFormatException
- 如果这些字节不表示一个有效的、UTF-8 修改版编码的字符串。
IOException
- 如果发生 I/O 错误。
void readFully(byte[] b, int off, int len) throws IOException
len
个字节,并将其存储到
b
中(从索引
off
开始)。如果到达流末尾,则将抛出
EOFException
。
在进行读取前,流中的位偏移量被重置为 0。
b
- 用来接收写入的 byte 数组。
off
- 向
b
进行写入的开始位置。
len
- 要读取的最大
byte
数。
IndexOutOfBoundsException
- 如果
off
为负、
len
为负或者
off + len
大于
b.length
。
NullPointerException
- 如果
b
为
null
。
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
void readFully(byte[] b) throws IOException
b.length
个字节,并将其存储到
b
中(从索引
0
开始)。如果到达流末尾,则将抛出
EOFException
。
在进行读取前,流中的位偏移量被重置为 0。
b
- 一个
byte
数组。
NullPointerException
- 如果
b
为
null
。
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
void readFully(short[] s, int off, int len) throws IOException
len
个 short(有符号 16 位整数),并将其存储到
s
中(从索引
off
开始)。如果到达流末尾,则将抛出
EOFException
。
在进行读取前,流中的位偏移量被重置为 0。
s
- 用来接收写入的 short 数组。
off
- 向 s 进行写入的开始位置。
len
- 要读取的最大
short
数。
IndexOutOfBoundsException
- 如果
off
为负、
len
为负或者
off + len
大于
s.length
。
NullPointerException
- 如果
s
为
null
。
EOFException
- 如果该流在读取所有字节之前到达末尾。
IOException
- 如果发生 I/O 错误。
void readFully(char[] c, int off, int len) throws IOException
len
个 char(无符号 16 位整数),并将其存储到
c
中(从索引
off
开始)。如果到达流末尾,则将抛出
EOFException
。
在进行读取前,流中的位偏移量被重置为 0。
c
- 用来接收写入的 char 数组。
off
- 向 c 进行写入的开始位置。
len
- 要读取的最大
char
数。
IndexOutOfBoundsException
- 如果
off
为负、
len
为负或者
<