Class InflaterInputStream
- All Implemented Interfaces:
-
Closeable
,AutoCloseable
- Direct Known Subclasses:
-
GZIPInputStream
,ZipInputStream
public class InflaterInputStream extends FilterInputStream
- Since:
- 1.1
- See Also:
Field Summary
Modifier and Type | Field | Description |
---|---|---|
protected byte[] |
buf |
Input buffer for decompression. |
protected Inflater |
inf |
Decompressor for this stream. |
protected int |
len |
Length of input buffer. |
Fields declared in class java.io.FilterInputStream
in
Constructor Summary
Constructor | Description |
---|---|
InflaterInputStream |
Creates a new input stream with a default decompressor and buffer size. |
InflaterInputStream |
Creates a new input stream with the specified decompressor and a default buffer size. |
InflaterInputStream |
Creates a new input stream with the specified decompressor and buffer size. |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
int |
available() |
Returns 0 after EOF has been reached, otherwise always return 1. |
void |
close() |
Closes this input stream and releases any system resources associated with the stream. |
protected void |
fill() |
Fills input buffer with more data to decompress. |
void |
mark |
Marks the current position in this input stream. |
boolean |
markSupported() |
Tests if this input stream supports the mark and reset methods. |
int |
read() |
Reads a byte of uncompressed data. |
int |
read |
Reads uncompressed data into an array of bytes. |
void |
reset() |
Repositions this stream to the position at the time the mark method was last called on this input stream. |
long |
skip |
Skips specified number of bytes of uncompressed data. |
Methods declared in class java.io.FilterInputStream
read
Methods declared in class java.io.InputStream
nullInputStream, readAllBytes, readNBytes, readNBytes, skipNBytes, transferTo
Field Details
inf
protected Inflater inf
buf
protected byte[] buf
len
protected int len
Constructor Details
InflaterInputStream
public InflaterInputStream(InputStream in, Inflater inf, int size)
- Parameters:
-
in
- the input stream -
inf
- the decompressor ("inflater") -
size
- the input buffer size - Throws:
-
IllegalArgumentException
- ifsize <= 0
InflaterInputStream
public InflaterInputStream(InputStream in, Inflater inf)
- Parameters:
-
in
- the input stream -
inf
- the decompressor ("inflater")
InflaterInputStream
public InflaterInputStream(InputStream in)
- Parameters:
-
in
- the input stream
Method Details
read
public int read() throws IOException
- Overrides:
-
read
in classFilterInputStream
- Returns:
- the byte read, or -1 if end of compressed input is reached
- Throws:
-
IOException
- if an I/O error has occurred - See Also:
read
public int read(byte[] b, int off, int len) throws IOException
len
is not zero, the method will block until some input can be decompressed; otherwise, no bytes are read and 0
is returned.- Overrides:
-
read
in classFilterInputStream
- Parameters:
-
b
- the buffer into which the data is read -
off
- the start offset in the destination arrayb
-
len
- the maximum number of bytes read - Returns:
- the actual number of bytes read, or -1 if the end of the compressed input is reached or a preset dictionary is needed
- Throws:
-
NullPointerException
- Ifb
isnull
. -
IndexOutOfBoundsException
- Ifoff
is negative,len
is negative, orlen
is greater thanb.length - off
-
ZipException
- if a ZIP format error has occurred -
IOException
- if an I/O error has occurred - See Also:
available
public int available() throws IOException
Programs should not count on this method to return the actual number of bytes that could be read without blocking.
- Overrides:
-
available
in classFilterInputStream
- Returns:
- 1 before EOF and 0 after EOF.
- Throws:
-
IOException
- if an I/O error occurs.
skip
public long skip(long n) throws IOException
- Overrides:
-
skip
in classFilterInputStream
- Parameters:
-
n
- the number of bytes to skip - Returns:
- the actual number of bytes skipped.
- Throws:
-
IOException
- if an I/O error has occurred -
IllegalArgumentException
- ifn < 0
- See Also:
close
public void close() throws IOException
- Specified by:
-
close
in interfaceAutoCloseable
- Specified by:
-
close
in interfaceCloseable
- Overrides:
-
close
in classFilterInputStream
- Throws:
-
IOException
- if an I/O error has occurred - See Also:
fill
protected void fill() throws IOException
- Throws:
-
IOException
- if an I/O error has occurred
markSupported
public boolean markSupported()
mark
and reset
methods. The markSupported
method of InflaterInputStream
returns false
.- Overrides:
-
markSupported
in classFilterInputStream
- Returns:
- a
boolean
indicating if this stream type supports themark
andreset
methods. - See Also:
mark
public void mark(int readlimit)
The mark
method of InflaterInputStream
does nothing.
- Overrides:
-
mark
in classFilterInputStream
- Parameters:
-
readlimit
- the maximum limit of bytes that can be read before the mark position becomes invalid. - See Also:
reset
public void reset() throws IOException
mark
method was last called on this input stream. The method reset
for class InflaterInputStream
does nothing except throw an IOException
.
- Overrides:
-
reset
in classFilterInputStream
- Throws:
-
IOException
- if this method is invoked. - See Also:
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.base/java/util/zip/InflaterInputStream.html