Creates an output stream filter built on top of the specified underlying output stream.
Closes this output stream and releases any system resources associated with the stream. <p> When not already closed, the {@code close} method of {@code FilterOutputStream} calls its {@code flush} method, and then calls the {@code close} method of its underlying output stream.
Flushes this output stream and forces any buffered output bytes to be written out to the stream. <p> The <code>flush</code> method of <code>FilterOutputStream</code> calls the <code>flush</code> method of its underlying output stream.
Writes the specified <code>byte</code> to this output stream. <p> The <code>write</code> method of <code>FilterOutputStream</code> calls the <code>write</code> method of its underlying output stream, that is, it performs {@code outputStream.write(b)}. <p> Implements the abstract {@code write} method of {@code OutputStream}.
Writes <code>b.length</code> bytes to this output stream. <p> The <code>write</code> method of <code>FilterOutputStream</code> calls its <code>write</code> method of three arguments with the arguments <code>b</code>, <code>0</code>, and <code>b.length</code>. <p> Note that this method does not call the one-argument <code>write</code> method of its underlying output stream with the single argument <code>b</code>.
Writes <code>len</code> bytes from the specified <code>byte</code> array starting at offset <code>off</code> to this output stream. <p> The <code>write</code> method of <code>FilterOutputStream</code> calls the <code>write</code> method of one argument on each <code>byte</code> to output. <p> Note that this method does not call the <code>write</code> method of its underlying output stream with the same arguments. Subclasses of <code>FilterOutputStream</code> should provide a more efficient implementation of this method.
The underlying output stream to be filtered.
Writes the specified byte to this output stream. The general contract for <code>write</code> is that one byte is written to the output stream. The byte to be written is the eight low-order bits of the argument <code>b</code>. The 24 high-order bits of <code>b</code> are ignored. <p> Subclasses of <code>OutputStream</code> must provide an implementation for this method.
Writes <code>b.length</code> bytes from the specified byte array to this output stream. The general contract for <code>write(b)</code> is that it should have exactly the same effect as the call <code>write(b, 0, b.length)</code>.
Writes <code>len</code> bytes from the specified byte array starting at offset <code>off</code> to this output stream. The general contract for <code>write(b, off, len)</code> is that some of the bytes in the array <code>b</code> are written to the output stream in order; element <code>boff</code> is the first byte written and <code>b[off+len-1]</code> is the last byte written by this operation. <p> The <code>write</code> method of <code>OutputStream</code> calls the write method of one argument on each of the bytes to be written out. Subclasses are encouraged to override this method and provide a more efficient implementation. <p> If <code>b</code> is <code>null</code>, a <code>NullPointerException</code> is thrown. <p> If <code>off</code> is negative, or <code>len</code> is negative, or <code>off+len</code> is greater than the length of the array <code>b</code>, then an <tt>IndexOutOfBoundsException</tt> is thrown.
Flushes this output stream and forces any buffered output bytes to be written out. The general contract of <code>flush</code> is that calling it is an indication that, if any bytes previously written have been buffered by the implementation of the output stream, such bytes should immediately be written to their intended destination. <p> If the intended destination of this stream is an abstraction provided by the underlying operating system, for example a file, then flushing the stream guarantees only that bytes previously written to the stream are passed to the operating system for writing; it does not guarantee that they are actually written to a physical device such as a disk drive. <p> The <code>flush</code> method of <code>OutputStream</code> does nothing.
Closes this output stream and releases any system resources associated with this stream. The general contract of <code>close</code> is that it closes the output stream. A closed stream cannot perform output operations and cannot be reopened. <p> The <code>close</code> method of <code>OutputStream</code> does nothing.
This class is the superclass of all classes that filter output streams. These streams sit on top of an already existing output stream (the <i>underlying</i> output stream) which it uses as its basic sink of data, but possibly transforming the data along the way or providing additional functionality. <p> The class <code>FilterOutputStream</code> itself simply overrides all methods of <code>OutputStream</code> with versions that pass all requests to the underlying output stream. Subclasses of <code>FilterOutputStream</code> may further override some of these methods as well as provide additional methods and fields.
@author Jonathan Payne