- java.lang.Object
-
- javax.imageio.stream.ImageInputStreamImpl
-
- javax.imageio.stream.MemoryCacheImageInputStream
-
- All Implemented Interfaces:
Closeable
,DataInput
,AutoCloseable
,ImageInputStream
public class MemoryCacheImageInputStream extends ImageInputStreamImpl
An implementation ofImageInputStream
that gets its input from a regularInputStream
. A memory buffer is used to cache at least the data between the discard position and the current read position.In general, it is preferable to use a
FileCacheImageInputStream
when reading from a regularInputStream
. This class is provided for cases where it is not possible to create a writable temporary file.
-
-
Field Summary
-
Fields declared in class javax.imageio.stream.ImageInputStreamImpl
bitOffset, byteOrder, flushedPos, streamPos
-
-
Constructor Summary
Constructors Constructor Description MemoryCacheImageInputStream(InputStream stream)
Constructs aMemoryCacheImageInputStream
that will read from a givenInputStream
.
-
Method Summary
All Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description void
close()
Closes thisMemoryCacheImageInputStream
, freeing the cache.protected void
finalize()
Deprecated.Thefinalize
method has been deprecated.boolean
isCached()
Returnstrue
since thisImageInputStream
caches data in order to allow seeking backwards.boolean
isCachedFile()
Returnsfalse
since thisImageInputStream
does not maintain a file cache.boolean
isCachedMemory()
Returnstrue
since thisImageInputStream
maintains a main memory cache.-
Methods declared in interface javax.imageio.stream.ImageInputStream
flush, flushBefore, getBitOffset, getByteOrder, getFlushedPosition, getStreamPosition, readBit, readBits, readBoolean, readByte, readBytes, readChar, readDouble, readFloat, readFully, readFully, readFully, readFully, readFully, readFully, readFully, readFully, readInt, readLine, readLong, readShort, readUnsignedByte, readUnsignedInt, readUnsignedShort, readUTF, seek, setBitOffset, setByteOrder
-
Methods declared in class javax.imageio.stream.ImageInputStreamImpl
checkClosed, length, mark, read, read, read, reset, skipBytes, skipBytes
-
-
-
-
Constructor Detail
-
MemoryCacheImageInputStream
public MemoryCacheImageInputStream(InputStream stream)
Constructs aMemoryCacheImageInputStream
that will read from a givenInputStream
.- Parameters:
stream
- anInputStream
to read from.- Throws:
IllegalArgumentException
- ifstream
isnull
.
-
-
Method Detail
-
isCached
public boolean isCached()
Returnstrue
since thisImageInputStream
caches data in order to allow seeking backwards.- Specified by:
isCached
in interfaceImageInputStream
- Overrides:
isCached
in classImageInputStreamImpl
- Returns:
true
.- See Also:
isCachedMemory()
,isCachedFile()
-
isCachedFile
public boolean isCachedFile()
Returnsfalse
since thisImageInputStream
does not maintain a file cache.- Specified by:
isCachedFile
in interfaceImageInputStream
- Overrides:
isCachedFile
in classImageInputStreamImpl
- Returns:
false
.- See Also:
isCached()
,isCachedMemory()
-
isCachedMemory
public boolean isCachedMemory()
Returnstrue
since thisImageInputStream
maintains a main memory cache.- Specified by:
isCachedMemory
in interfaceImageInputStream
- Overrides:
isCachedMemory
in classImageInputStreamImpl
- Returns:
true
.- See Also:
isCached()
,isCachedFile()
-
close
public void close() throws IOException
Closes thisMemoryCacheImageInputStream
, freeing the cache. The sourceInputStream
is not closed.- Throws:
IOException
- if an I/O error occurs.
-
finalize
@Deprecated(since="9") protected void finalize() throws Throwable
Deprecated.Thefinalize
method has been deprecated. Subclasses that overridefinalize
in order to perform cleanup should be modified to use alternative cleanup mechanisms and to remove the overridingfinalize
method. When overriding thefinalize
method, its implementation must explicitly ensure thatsuper.finalize()
is invoked as described inObject.finalize()
. See the specification forObject.finalize()
for further information about migration options.Finalizes this object prior to garbage collection. Theclose
method is called to close any open input source. This method should not be called from application code.- Overrides:
finalize
in classImageInputStreamImpl
- Throws:
Throwable
- if an error occurs during superclass finalization.- See Also:
WeakReference
,PhantomReference
-
-