Package org.apache.axiom.blob
Interface MemoryBlob
-
- All Superinterfaces:
Blob,WritableBlob
public interface MemoryBlob extends WritableBlob
Blob that stores data in memory.This interface redefines several methods from
BlobandWritableBlobto not throwIOException. Also note that since data is stored in memory, callingWritableBlob.release()is not required.Instances are created with
Blobs.createMemoryBlob()or usingFACTORY.
-
-
Field Summary
Fields Modifier and Type Field Description static WritableBlobFactory<MemoryBlob>FACTORY
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description MemoryBlobInputStreamgetInputStream()Get an input stream to read the data in the blob.MemoryBlobOutputStreamgetOutputStream()Create an output stream to write data to the blob.longgetSize()Get the size of the blob.MemoryBlobInputStreamreadOnce()Get an input stream that consumes the content of this blob.voidrelease()Release all resources held by this blob.-
Methods inherited from interface org.apache.axiom.blob.WritableBlob
readFrom
-
-
-
-
Field Detail
-
FACTORY
static final WritableBlobFactory<MemoryBlob> FACTORY
-
-
Method Detail
-
getInputStream
MemoryBlobInputStream getInputStream()
Description copied from interface:BlobGet an input stream to read the data in the blob. A newInputStreamobject is returned each time this method is called, and the stream is positioned at the beginning of the data.- Specified by:
getInputStreamin interfaceBlob- Returns:
- the input stream to read the data from
-
getOutputStream
MemoryBlobOutputStream getOutputStream()
Description copied from interface:WritableBlobCreate an output stream to write data to the blob. The blob must be in state NEW when this method is called. It will be in state UNCOMMITTED after this method completes successfully. Note that this implies that this method may be called at most once for a given blob instance.Calls to methods of the returned output stream will modify the state of the blob according to the following rules:
- A call to
OutputStream.close()will change the state to COMMITTED. - Calls to other methods will not modify the state of the blob. They will result in
an
IOExceptionif the state is COMMITTED, i.e. if the stream has already been closed.
The returned stream may implement
ReadFromSupport, especially if the blob stores its data in memory (in which caseReadFromSupport.readFrom(InputStream, long)would read data directly into the buffers managed by the blob).- Specified by:
getOutputStreamin interfaceWritableBlob- Returns:
- an output stream that can be used to write data to the blob
- A call to
-
getSize
long getSize()
Description copied from interface:BlobGet the size of the blob.
-
release
void release()
Description copied from interface:WritableBlobRelease all resources held by this blob. This method will put the blob into the RELEASED state and the content will no longer be accessible.- Specified by:
releasein interfaceWritableBlob
-
readOnce
MemoryBlobInputStream readOnce()
Get an input stream that consumes the content of this blob. The memory held by this blob will be gradually released as data is read from the stream.- Returns:
- the input stream to read the data from
-
-