InflaterInputStream (Java SE 13 & JDK 13 )
- All Implemented Interfaces:
Closeable,AutoCloseable
- Direct Known Subclasses:
GZIPInputStream,ZipInputStream
public class InflaterInputStream extends FilterInputStream
This class implements a stream filter for uncompressing data in the "deflate" compression format. It is also used as the basis for other decompression filters, such as GZIPInputStream.
- Since:
- 1.1
- See Also:
Inflater
-
Field Summary
-
Constructor Summary
Constructors Constructor Description InflaterInputStream(InputStream in)Creates a new input stream with a default decompressor and buffer size.
InflaterInputStream(InputStream in, Inflater inf)Creates a new input stream with the specified decompressor and a default buffer size.
InflaterInputStream(InputStream in, Inflater inf, int size)Creates a new input stream with the specified decompressor and buffer size.
-
Method Summary
Modifier and Type Method Description intavailable()Returns 0 after EOF has been reached, otherwise always return 1.
voidclose()Closes this input stream and releases any system resources associated with the stream.
protected voidfill()Fills input buffer with more data to decompress.
voidmark(int readlimit)Marks the current position in this input stream.
booleanmarkSupported()Tests if this input stream supports the
markandresetmethods.intread()Reads a byte of uncompressed data.
intread(byte[] b, int off, int len)Reads uncompressed data into an array of bytes.
voidreset()Repositions this stream to the position at the time the
markmethod was last called on this input stream.longskip(long n)Skips specified number of bytes of uncompressed data.
-
Field Details
-
Constructor Details
-
InflaterInputStream
Creates a new input stream with the specified decompressor and buffer size.
- Parameters:
in- the input streaminf- the decompressor ("inflater")size- the input buffer size- Throws:
IllegalArgumentException- ifsize <= 0
-
InflaterInputStream
Creates a new input stream with the specified decompressor and a default buffer size.
- Parameters:
in- the input streaminf- the decompressor ("inflater")
-
InflaterInputStream
Creates a new input stream with a default decompressor and buffer size.
- Parameters:
in- the input stream
-
-
Method Details
-
read
Reads a byte of uncompressed data. This method will block until enough input is available for decompression.
- Overrides:
readin 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:
FilterInputStream.in
-
read
public int read(byte[] b, int off, int len) throws IOException
Reads uncompressed data into an array of bytes. If
lenis not zero, the method will block until some input can be decompressed; otherwise, no bytes are read and0is returned.- Overrides:
readin classFilterInputStream- Parameters:
b- the buffer into which the data is readoff- the start offset in the destination arrayblen- 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- Ifbisnull.IndexOutOfBoundsException- Ifoffis negative,lenis negative, orlenis greater thanb.length - offZipException- if a ZIP format error has occurredIOException- if an I/O error has occurred- See Also:
FilterInputStream.in
-
available
Returns 0 after EOF has been reached, otherwise always return 1.
Programs should not count on this method to return the actual number of bytes that could be read without blocking.
- Overrides:
availablein classFilterInputStream- Returns:
- 1 before EOF and 0 after EOF.
- Throws:
IOException- if an I/O error occurs.
-
skip
Skips specified number of bytes of uncompressed data.
- Overrides:
skipin classFilterInputStream- Parameters:
n- the number of bytes to skip- Returns:
- the actual number of bytes skipped.
- Throws:
IOException- if an I/O error has occurredIllegalArgumentException- ifn < 0- See Also:
InputStream.skipNBytes(long)
-
close
Closes this input stream and releases any system resources associated with the stream.
- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Overrides:
closein classFilterInputStream- Throws:
IOException- if an I/O error has occurred- See Also:
FilterInputStream.in
-
fill
Fills input buffer with more data to decompress.
- Throws:
IOException- if an I/O error has occurred
-
markSupported
public boolean markSupported()
Tests if this input stream supports the
markandresetmethods. ThemarkSupportedmethod ofInflaterInputStreamreturnsfalse.- Overrides:
markSupportedin classFilterInputStream- Returns:
- a
booleanindicating if this stream type supports themarkandresetmethods. - See Also:
InputStream.mark(int),InputStream.reset()
-
mark
public void mark(int readlimit)
Marks the current position in this input stream.
The
markmethod ofInflaterInputStreamdoes nothing.- Overrides:
markin classFilterInputStream- Parameters:
readlimit- the maximum limit of bytes that can be read before the mark position becomes invalid.- See Also:
InputStream.reset()
-
reset
Repositions this stream to the position at the time the
markmethod was last called on this input stream.The method
resetfor classInflaterInputStreamdoes nothing except throw anIOException.- Overrides:
resetin classFilterInputStream- Throws:
IOException- if this method is invoked.- See Also:
InputStream.mark(int),IOException
-
Report a bug or suggest an enhancement
For further API reference and developer documentation see the Java SE Documentation, which contains more detailed, developer-targeted descriptions with conceptual overviews, definitions of terms, workarounds, and working code examples.
Java is a trademark or registered trademark of Oracle and/or its affiliates in the US and other countries.
Copyright © 1993, 2019, Oracle and/or its affiliates, 500 Oracle Parkway, Redwood Shores, CA 94065 USA.
All rights reserved. Use is subject to license terms and the documentation redistribution policy.