public class ServletOutputStreamImpl extends javax.servlet.ServletOutputStream implements BufferWritableOutputStream
If a content-length header was present when the stream was created then it will automatically close and flush itself once the appropriate amount of data has been written.
Once the listener has been set it goes into async mode, and writes become non blocking. Most methods have two different code paths, based on if the listener has been set or not
Once the write listener has been set operations must only be invoked on this stream from the write listener callback. Attempting to invoke from a different thread will result in an IllegalStateException.
Async listener tasks are queued in the AsyncContextImpl
. At most one listener can be active at one time, which simplifies the thread safety requirements.
Constructor and Description |
---|
ServletOutputStreamImpl(ServletRequestContext servletRequestContext) Construct a new instance. |
ServletOutputStreamImpl(ServletRequestContext servletRequestContext, int bufferSize) Construct a new instance. |
Modifier and Type | Method and Description |
---|---|
void | close() |
void | closeAsync() Closes the channel, and flushes any data out using async IO |
void | flush() |
void | flushInternal() |
boolean | isClosed() |
boolean | isReady() |
void | resetBuffer() |
void | setBufferSize(int size) |
void | setWriteListener(javax.servlet.WriteListener writeListener) |
void | transferFrom(FileChannel source) |
void | write(byte[] b) |
void | write(byte[] b, int off, int len) |
void | write(ByteBuffer byteBuffer) |
void | write(ByteBuffer[] buffers) |
void | write(int b) |
public ServletOutputStreamImpl(ServletRequestContext servletRequestContext)
public ServletOutputStreamImpl(ServletRequestContext servletRequestContext, int bufferSize)
public void write(int b) throws IOException
write
in class OutputStream
IOException
public void write(byte[] b) throws IOException
write
in class OutputStream
IOException
public void write(byte[] b, int off, int len) throws IOException
write
in class OutputStream
IOException
public void write(ByteBuffer[] buffers) throws IOException
write
in interface BufferWritableOutputStream
IOException
public void write(ByteBuffer byteBuffer) throws IOException
write
in interface BufferWritableOutputStream
IOException
public void flush() throws IOException
flush
in interface Flushable
flush
in class OutputStream
IOException
public void flushInternal() throws IOException
IOException
public void transferFrom(FileChannel source) throws IOException
transferFrom
in interface BufferWritableOutputStream
IOException
public void close() throws IOException
close
in interface Closeable
close
in interface AutoCloseable
close
in class OutputStream
IOException
public void closeAsync() throws IOException
This is used in two situations, if an output stream is not closed when a request is done, and when performing a close on a stream that is in async mode
IOException
public void resetBuffer()
public void setBufferSize(int size)
public boolean isClosed()
public boolean isReady()
isReady
in class javax.servlet.ServletOutputStream
public void setWriteListener(javax.servlet.WriteListener writeListener)
setWriteListener
in class javax.servlet.ServletOutputStream
Copyright © 2020 JBoss by Red Hat. All rights reserved.