Class WriteBuffer
java.lang.Object
org.apache.tomcat.util.net.WriteBuffer
Provides an expandable set of buffers for writes. Non-blocking writes can be of any size and may not be able to be
written immediately or wholly contained in the buffer used to perform the writes to the next layer. This class
provides a buffering capability to allow such writes to return immediately and also allows for the user provided
buffers to be re-used / recycled as required.
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic interfaceInterface implemented by clients of the WriteBuffer to enable data to be written back out from the buffer. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidadd(ByteBuffer from) Adds data from a ByteBuffer to this write buffer.booleanisEmpty()Returns whether this write buffer is empty.booleanwrite(WriteBuffer.Sink sink, boolean blocking) Writes data from this buffer to the given sink.
-
Constructor Details
-
WriteBuffer
public WriteBuffer(int bufferSize) Constructs a new WriteBuffer.- Parameters:
bufferSize- The size of internal buffers
-
-
Method Details
-
add
Adds data from a ByteBuffer to this write buffer.- Parameters:
from- The source ByteBuffer
-
isEmpty
public boolean isEmpty()Returns whether this write buffer is empty.- Returns:
trueif empty
-
write
Writes data from this buffer to the given sink.- Parameters:
sink- The sink to write toblocking- Whether to use blocking writes- Returns:
trueif data is left unwritten,falseotherwise- Throws:
IOException- If an I/O error occurs
-