java.io
Class ByteArrayInputStream

java.lang.Object
  extended by java.io.InputStream
      extended by java.io.ByteArrayInputStream

public class ByteArrayInputStream
extends InputStream

ByteArrayInputStream is used for streaming over a byte array.

See Also:
ByteArrayOutputStream

Field Summary
protected  byte[] buf
          The byte array containing the bytes to stream over.
protected  int count
          The total number of bytes initially available in the byte array buf.
protected  int mark
          The current mark position.
protected  int pos
          The current position within the byte array.
 
Constructor Summary
ByteArrayInputStream(byte[] buf)
          Constructs a new ByteArrayInputStream on the byte array buf.
ByteArrayInputStream(byte[] buf, int offset, int length)
          Constructs a new ByteArrayInputStream on the byte array buf with the position set to offset and the number of bytes available set to offset + length.
 
Method Summary
 int available()
          Answers a int representing then number of bytes that are available before this ByteArrayInputStream will block.
 void close()
          Close the ByteArrayInputStream.
 int read()
          Reads a single byte from this ByteArrayInputStream and returns the result as an int.
 int read(byte[] b, int offset, int length)
          Reads at most len bytes from this ByteArrayInputStream and stores them in byte array b starting at offset off.
 long skip(long n)
          Skips count number of bytes in this InputStream.
 
Methods inherited from class java.io.InputStream
mark, markSupported, read, reset
 
Methods inherited from class java.lang.Object
clone, equals, getClass, hashCode, println, toString
 

Field Detail

buf

protected byte[] buf
The byte array containing the bytes to stream over.


pos

protected int pos
The current position within the byte array.


mark

protected int mark
The current mark position. Initially set to 0 or the offset parameter within the constructor.


count

protected int count
The total number of bytes initially available in the byte array buf.

Constructor Detail

ByteArrayInputStream

public ByteArrayInputStream(byte[] buf)
Constructs a new ByteArrayInputStream on the byte array buf.

Parameters:
buf - the byte array to stream over

ByteArrayInputStream

public ByteArrayInputStream(byte[] buf,
                            int offset,
                            int length)
Constructs a new ByteArrayInputStream on the byte array buf with the position set to offset and the number of bytes available set to offset + length.

Parameters:
buf - the byte array to stream over
offset - the offset in buf to start streaming at
length - the number of bytes available to stream over.
Method Detail

available

public int available()
Answers a int representing then number of bytes that are available before this ByteArrayInputStream will block. This method returns the number of bytes yet to be read from the underlying byte array.

Overrides:
available in class InputStream
Returns:
the number of bytes available before blocking.

close

public void close()
           throws IOException
Close the ByteArrayInputStream. This implementation frees up resources associated with this stream.

Overrides:
close in class InputStream
Throws:
IOException - If an error occurs attempting to close this InputStream.

read

public int read()
Reads a single byte from this ByteArrayInputStream and returns the result as an int. The low-order byte is returned or -1 of the end of stream was encountered. This implementation returns the next available byte from the target byte array.

Specified by:
read in class InputStream
Returns:
the byte read or -1 if end of stream.

read

public int read(byte[] b,
                int offset,
                int length)
Reads at most len bytes from this ByteArrayInputStream and stores them in byte array b starting at offset off. Answer the number of bytes actually read or -1 if no bytes were read and end of stream was encountered. This implementation reads bytes from the target byte array.

Overrides:
read in class InputStream
Parameters:
b - the byte array in which to store the read bytes.
offset - the offset in b to store the read bytes.
length - the maximum number of bytes to store in b.
Returns:
the number of bytes actually read or -1 if end of stream.

skip

public long skip(long n)
Skips count number of bytes in this InputStream. Subsequent read()'s will not return these bytes unless reset() is used. This implementation skips count number of bytes in the target stream.

Overrides:
skip in class InputStream
Parameters:
n - the number of bytes to skip.
Returns:
the number of bytes actually skipped.