Package jakarta.mail.util
Class SharedByteArrayInputStream
java.lang.Object
java.io.InputStream
java.io.ByteArrayInputStream
jakarta.mail.util.SharedByteArrayInputStream
- All Implemented Interfaces:
SharedInputStream
,Closeable
,AutoCloseable
A ByteArrayInputStream that implements the SharedInputStream interface,
allowing the underlying byte array to be shared between multiple readers.
- Since:
- JavaMail 1.4
- Author:
- Bill Shannon
-
Field Summary
Modifier and TypeFieldDescriptionprotected int
Position within shared buffer that this stream starts at.Fields inherited from class java.io.ByteArrayInputStream
buf, count, mark, pos
-
Constructor Summary
ConstructorDescriptionSharedByteArrayInputStream
(byte[] buf) Create a SharedByteArrayInputStream representing the entire byte array.SharedByteArrayInputStream
(byte[] buf, int offset, int length) Create a SharedByteArrayInputStream representing the part of the byte array fromoffset
forlength
bytes. -
Method Summary
Modifier and TypeMethodDescriptionlong
Return the current position in the InputStream, as an offset from the beginning of the InputStream.newStream
(long start, long end) Return a new InputStream representing a subset of the data from this InputStream, starting atstart
(inclusive) up toend
(exclusive).Methods inherited from class java.io.ByteArrayInputStream
available, close, mark, markSupported, read, read, readAllBytes, readNBytes, reset, skip, transferTo
Methods inherited from class java.io.InputStream
nullInputStream, read, readNBytes, skipNBytes
-
Field Details
-
start
protected int startPosition within shared buffer that this stream starts at.
-
-
Constructor Details
-
SharedByteArrayInputStream
public SharedByteArrayInputStream(byte[] buf) Create a SharedByteArrayInputStream representing the entire byte array.- Parameters:
buf
- the byte array
-
SharedByteArrayInputStream
public SharedByteArrayInputStream(byte[] buf, int offset, int length) Create a SharedByteArrayInputStream representing the part of the byte array fromoffset
forlength
bytes.- Parameters:
buf
- the byte arrayoffset
- offset in byte array to first byte to includelength
- number of bytes to include
-
-
Method Details
-
getPosition
public long getPosition()Return the current position in the InputStream, as an offset from the beginning of the InputStream.- Specified by:
getPosition
in interfaceSharedInputStream
- Returns:
- the current position
-
newStream
Return a new InputStream representing a subset of the data from this InputStream, starting atstart
(inclusive) up toend
(exclusive).start
must be non-negative. Ifend
is -1, the new stream ends at the same place as this stream. The returned InputStream will also implement the SharedInputStream interface.- Specified by:
newStream
in interfaceSharedInputStream
- Parameters:
start
- the starting positionend
- the ending position + 1- Returns:
- the new stream
-