Class SdkInputStream
- java.lang.Object
- 
- java.io.InputStream
- 
- software.amazon.awssdk.core.io.SdkInputStream
 
 
- 
- All Implemented Interfaces:
- Closeable,- AutoCloseable,- Releasable
 - Direct Known Subclasses:
- AwsChunkedInputStream
 
 public abstract class SdkInputStream extends InputStream implements Releasable Base class for AWS Java SDK specificInputStream.
- 
- 
Constructor SummaryConstructors Constructor Description SdkInputStream()
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected voidabort()Can be used to provide abortion logic prior to throwing the AbortedException.protected voidabortIfNeeded()Aborts with subclass specific abortion logic executed if needed.protected abstract InputStreamgetWrappedInputStream()Returns the underlying input stream, if any, from the subclass; or null if there is no underlying input stream.voidrelease()WARNING: Subclass that overrides this method must NOT call super.release() or else it would lead to infinite loop.- 
Methods inherited from class java.io.InputStreamavailable, close, mark, markSupported, read, read, read, reset, skip
 
- 
 
- 
- 
- 
Method Detail- 
getWrappedInputStreamprotected abstract InputStream getWrappedInputStream() Returns the underlying input stream, if any, from the subclass; or null if there is no underlying input stream.
 - 
abortIfNeededprotected final void abortIfNeeded() Aborts with subclass specific abortion logic executed if needed. Note the interrupted status of the thread is cleared by this method.- Throws:
- AbortedException- if found necessary.
 
 - 
abortprotected void abort() throws IOExceptionCan be used to provide abortion logic prior to throwing the AbortedException. No-op by default.- Throws:
- IOException
 
 - 
releasepublic void release() WARNING: Subclass that overrides this method must NOT call super.release() or else it would lead to infinite loop.Releases the allocated resource. This method should not be called except by the caller who allocated the resource at the very top of the call stack. This allows, typically, a Closeableresource to be not unintentionally released owing to the calling of theCloseable.close()methods by implementation deep down in the call stack.For example, the creation of a ResettableInputStreamwould entail physically opening a file. If the opened file is meant to be closed only (in a finally block) by the very same code block that created it, then it is necessary that the release method must not be called while the execution is made in other stack frames. In such case, as other stack frames may inadvertently or indirectly call the close method of the stream, the creator of the stream would need to explicitly disable the accidental closing viaResettableInputStream#disableClose(), so that the release method becomes the only way to truly close the opened file.- Specified by:
- releasein interface- Releasable
 
 
- 
 
-