Package jakarta.mail.util
Class SharedFileInputStream
java.lang.Object
java.io.InputStream
java.io.FilterInputStream
java.io.BufferedInputStream
jakarta.mail.util.SharedFileInputStream
- All Implemented Interfaces:
- SharedInputStream,- Closeable,- AutoCloseable
A 
SharedFileInputStream is a
 BufferedInputStream that buffers
 data from the file and supports the mark
 and reset methods.  It also supports the
 newStream method that allows you to create
 other streams that represent subsets of the file.
 A RandomAccessFile object is used to
 access the file data. 
 Note that when the SharedFileInputStream is closed,
 all streams created with the newStream
 method are also closed.  This allows the creator of the
 SharedFileInputStream object to control access to the
 underlying file and ensure that it is closed when
 needed, to avoid leaking file descriptors.  Note also
 that this behavior contradicts the requirements of
 SharedInputStream and may change in a future release.
- Since:
- JavaMail 1.4
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected longThe file offset that corresponds to the first byte in the read buffer.protected intThe normal size of the read buffer.protected longThe amount of data in this subset of the file.protected RandomAccessFileThe file containing the data.protected longThe file offset of the start of data in this subset of the file.
- 
Constructor SummaryConstructorsConstructorDescriptionSharedFileInputStream(File file) Creates aSharedFileInputStreamfor the file.SharedFileInputStream(File file, int size) Creates aSharedFileInputStreamwith the specified buffer size.SharedFileInputStream(String file) Creates aSharedFileInputStreamfor the named fileSharedFileInputStream(String file, int size) Creates aSharedFileInputStreamwith the specified buffer size.
- 
Method SummaryModifier and TypeMethodDescriptionintReturns the number of bytes that can be read from this input stream without blocking.voidclose()Closes this input stream and releases any system resources associated with the stream.protected voidfinalize()Force this stream to close.longReturn the current position in the InputStream, as an offset from the beginning of the InputStream.voidmark(int readlimit) See the general contract of themarkmethod ofInputStream.booleanTests if this input stream supports themarkandresetmethods.newStream(long start, long end) Return a new InputStream representing a subset of the data from this InputStream, starting atstart(inclusive) up toend(exclusive).intread()See the general contract of thereadmethod ofInputStream.intread(byte[] b, int off, int len) Reads bytes from this stream into the specified byte array, starting at the given offset.voidreset()See the general contract of theresetmethod ofInputStream.longskip(long n) See the general contract of theskipmethod ofInputStream.Methods inherited from class java.io.FilterInputStreamreadMethods inherited from class java.io.InputStreamnullInputStream, readAllBytes, readNBytes, readNBytes, skipNBytes, transferTo
- 
Field Details- 
inThe file containing the data. Shared by all related SharedFileInputStreams.
- 
bufsizeprotected int bufsizeThe normal size of the read buffer.
- 
bufposprotected long bufposThe file offset that corresponds to the first byte in the read buffer.
- 
startprotected long startThe file offset of the start of data in this subset of the file.
- 
datalenprotected long datalenThe amount of data in this subset of the file.
 
- 
- 
Constructor Details- 
SharedFileInputStreamCreates aSharedFileInputStreamfor the file.- Parameters:
- file- the file
- Throws:
- IOException- for errors opening the file
 
- 
SharedFileInputStreamCreates aSharedFileInputStreamfor the named file- Parameters:
- file- the file
- Throws:
- IOException- for errors opening the file
 
- 
SharedFileInputStreamCreates aSharedFileInputStreamwith the specified buffer size.- Parameters:
- file- the file
- size- the buffer size.
- Throws:
- IOException- for errors opening the file
- IllegalArgumentException- if size ≤ 0.
 
- 
SharedFileInputStreamCreates aSharedFileInputStreamwith the specified buffer size.- Parameters:
- file- the file
- size- the buffer size.
- Throws:
- IOException- for errors opening the file
- IllegalArgumentException- if size ≤ 0.
 
 
- 
- 
Method Details- 
readSee the general contract of thereadmethod ofInputStream.- Overrides:
- readin class- BufferedInputStream
- Returns:
- the next byte of data, or -1if the end of the stream is reached.
- Throws:
- IOException- if an I/O error occurs.
 
- 
readReads bytes from this stream into the specified byte array, starting at the given offset.This method implements the general contract of the corresponding readInputStream- Overrides:
- readin class- BufferedInputStream
- Parameters:
- b- destination buffer.
- off- offset at which to start storing bytes.
- len- maximum number of bytes to read.
- Returns:
- the number of bytes read, or -1if the end of the stream has been reached.
- Throws:
- IOException- if an I/O error occurs.
 
- 
skipSee the general contract of theskipmethod ofInputStream.- Overrides:
- skipin class- BufferedInputStream
- Parameters:
- n- the number of bytes to be skipped.
- Returns:
- the actual number of bytes skipped.
- Throws:
- IOException- if an I/O error occurs.
 
- 
availableReturns the number of bytes that can be read from this input stream without blocking.- Overrides:
- availablein class- BufferedInputStream
- Returns:
- the number of bytes that can be read from this input stream without blocking.
- Throws:
- IOException- if an I/O error occurs.
 
- 
markpublic void mark(int readlimit) See the general contract of themarkmethod ofInputStream.- Overrides:
- markin class- BufferedInputStream
- Parameters:
- readlimit- the maximum limit of bytes that can be read before the mark position becomes invalid.
- See Also:
 
- 
resetSee the general contract of theresetmethod ofInputStream.If markposis-1(no mark has been set or the mark has been invalidated), anIOExceptionis thrown. Otherwise,posis set equal tomarkpos.- Overrides:
- resetin class- BufferedInputStream
- Throws:
- IOException- if this stream has not been marked or if the mark has been invalidated.
- See Also:
 
- 
markSupportedpublic boolean markSupported()Tests if this input stream supports themarkandresetmethods. ThemarkSupportedmethod ofSharedFileInputStreamreturnstrue.- Overrides:
- markSupportedin class- BufferedInputStream
- Returns:
- a booleanindicating if this stream type supports themarkandresetmethods.
- See Also:
 
- 
closeCloses this input stream and releases any system resources associated with the stream.- Specified by:
- closein interface- AutoCloseable
- Specified by:
- closein interface- Closeable
- Overrides:
- closein class- BufferedInputStream
- Throws:
- IOException- if an I/O error occurs.
 
- 
getPositionpublic long getPosition()Return the current position in the InputStream, as an offset from the beginning of the InputStream.- Specified by:
- getPositionin interface- SharedInputStream
- Returns:
- the current position
 
- 
newStreamReturn a new InputStream representing a subset of the data from this InputStream, starting atstart(inclusive) up toend(exclusive).startmust be non-negative. Ifendis -1, the new stream ends at the same place as this stream. The returned InputStream will also implement the SharedInputStream interface.- Specified by:
- newStreamin interface- SharedInputStream
- Parameters:
- start- the starting position
- end- the ending position + 1
- Returns:
- the new stream
 
- 
finalizeForce this stream to close.
 
-