Closeable, Flushable, AutoCloseableGZIPOutputStream, ZipOutputStreampublic class DeflaterOutputStream extends FilterOutputStream
Unless otherwise noted, passing a null argument to a constructor or method in this class will cause a NullPointerException to be thrown.
DeflaterOutputStream created without specifying a compressor will create a compressor at construction time, and close the compressor when the output stream is closed. If a compressor is specified when creating a DeflaterOutputStream, it is the responsibility of the caller to close the compressor after closing the output stream.
close() method should be called to release resources used by this stream, either directly, or with the try-with-resources statement.| Modifier and Type | Field | Description |
|---|---|---|
protected byte[] |
buf |
Output buffer for writing compressed data. |
protected Deflater |
def |
Compressor for this stream. |
out
| Constructor | Description |
|---|---|
DeflaterOutputStream |
Creates a new output stream and compressor with the default compression level and a default buffer size. |
DeflaterOutputStream |
Creates a new output stream and compressor with the default compression level, a default buffer size and the specified flush mode. |
DeflaterOutputStream |
Creates a new output stream with the specified compressor and a default buffer size. |
DeflaterOutputStream |
Creates a new output stream with the specified compressor, flush mode and a default buffer size. |
DeflaterOutputStream |
Creates a new output stream with the specified compressor and buffer size. |
DeflaterOutputStream |
Creates a new output stream with the specified compressor, buffer size and flush mode. |
| Modifier and Type | Method | Description |
|---|---|---|
void |
close() |
Writes remaining compressed data to the output stream and closes the underlying stream. |
protected void |
deflate() |
Writes next block of compressed data to the output stream. |
void |
finish() |
Finishes writing compressed data to the output stream without closing the underlying stream. |
void |
flush() |
Flushes the compressed output stream. |
void |
write |
Writes an array of bytes to the compressed output stream. |
void |
write |
Writes a byte to the compressed output stream. |
write
nullOutputStream
protected Deflater def
protected byte[] buf
public DeflaterOutputStream(OutputStream out, Deflater def, int size, boolean syncFlush)
Closing this output stream will not close the given compressor.
out - the output streamdef - the compressor ("deflater")size - the output buffer sizesyncFlush - if true the flush() method of this instance flushes the compressor with flush mode Deflater.SYNC_FLUSH before flushing the output stream, otherwise only flushes the output streamIllegalArgumentException - if size <= 0
public DeflaterOutputStream(OutputStream out, Deflater def, int size)
The new output stream instance is created as if by invoking the 4-argument constructor DeflaterOutputStream(out, def, size, false).
Closing this output stream will not close the given compressor.
out - the output streamdef - the compressor ("deflater")size - the output buffer sizeIllegalArgumentException - if size <= 0
public DeflaterOutputStream(OutputStream out, Deflater def, boolean syncFlush)
Closing this output stream will not close the given compressor.
out - the output streamdef - the compressor ("deflater")syncFlush - if true the flush() method of this instance flushes the compressor with flush mode Deflater.SYNC_FLUSH before flushing the output stream, otherwise only flushes the output streampublic DeflaterOutputStream(OutputStream out, Deflater def)
The new output stream instance is created as if by invoking the 3-argument constructor DeflaterOutputStream(out, def, false).
Closing this output stream will not close the given compressor.
out - the output streamdef - the compressor ("deflater")public DeflaterOutputStream(OutputStream out, boolean syncFlush)
The compressor will be closed when this output stream is closed.
out - the output streamsyncFlush - if true the flush() method of this instance flushes the compressor with flush mode Deflater.SYNC_FLUSH before flushing the output stream, otherwise only flushes the output streampublic DeflaterOutputStream(OutputStream out)
The new output stream instance is created as if by invoking the 2-argument constructor DeflaterOutputStream(out, false).
The compressor will be closed when this output stream is closed.
out - the output streampublic void write(int b) throws IOException
write in class FilterOutputStream
b - the byte to be writtenIOException - if an I/O error has occurredpublic void write(byte[] b, int off, int len) throws IOException
write in class FilterOutputStream
b - the data to be writtenoff - the start offset of the datalen - the length of the dataIOException - if an I/O error has occurredpublic void finish() throws IOException
IOException - if an I/O error has occurredpublic void close() throws IOException
close in interface AutoCloseable
close in interface Closeable
close in class FilterOutputStream
IOException - if an I/O error has occurredprotected void deflate() throws IOException
IOException - if an I/O error has occurredpublic void flush() throws IOException
syncFlush is true when this compressed output stream is constructed, this method first flushes the underlying compressor with the flush mode Deflater.SYNC_FLUSH to force all pending data to be flushed out to the output stream and then flushes the output stream. Otherwise this method only flushes the output stream without flushing the compressor.flush in interface Flushable
flush in class FilterOutputStream
IOException - if an I/O error has occurred
© 1993, 2025, 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/25/docs/api/java.base/java/util/zip/DeflaterOutputStream.html