@Beta @GwtIncompatible public final class ByteStreams extends Object
| Modifier and Type | Method and Description | 
|---|---|
| static long | copy(InputStream from,
    OutputStream to)Copies all bytes from the input stream to the output stream. | 
| static long | copy(ReadableByteChannel from,
    WritableByteChannel to)Copies all bytes from the readable channel to the writable channel. | 
| static long | exhaust(InputStream in)Reads and discards data from the given  InputStreamuntil the end of the stream is
 reached. | 
| static InputStream | limit(InputStream in,
     long limit)Wraps a  InputStream, limiting the number of bytes which can be read. | 
| static ByteArrayDataInput | newDataInput(byte[] bytes)Returns a new  ByteArrayDataInputinstance to read from thebytesarray from the
 beginning. | 
| static ByteArrayDataInput | newDataInput(byte[] bytes,
            int start)Returns a new  ByteArrayDataInputinstance to read from thebytesarray,
 starting at the given position. | 
| static ByteArrayDataInput | newDataInput(ByteArrayInputStream byteArrayInputStream)Returns a new  ByteArrayDataInputinstance to read from the givenByteArrayInputStream. | 
| static ByteArrayDataOutput | newDataOutput()Returns a new  ByteArrayDataOutputinstance with a default size. | 
| static ByteArrayDataOutput | newDataOutput(ByteArrayOutputStream byteArrayOutputSteam)Returns a new  ByteArrayDataOutputinstance which writes to the givenByteArrayOutputStream. | 
| static ByteArrayDataOutput | newDataOutput(int size)Returns a new  ByteArrayDataOutputinstance sized to holdsizebytes before
 resizing. | 
| static OutputStream | nullOutputStream()Returns an  OutputStreamthat simply discards written bytes. | 
| static int | read(InputStream in,
    byte[] b,
    int off,
    int len)Reads some bytes from an input stream and stores them into the buffer array  b. | 
| static <T> T | readBytes(InputStream input,
         ByteProcessor<T> processor)Process the bytes of the given input stream using the given processor. | 
| static void | readFully(InputStream in,
         byte[] b)Attempts to read enough bytes from the stream to fill the given byte array, with the same
 behavior as  DataInput.readFully(byte[]). | 
| static void | readFully(InputStream in,
         byte[] b,
         int off,
         int len)Attempts to read  lenbytes from the stream into the given array starting atoff, with the same behavior asDataInput.readFully(byte[], int, int). | 
| static void | skipFully(InputStream in,
         long n)Discards  nbytes of data from the input stream. | 
| static byte[] | toByteArray(InputStream in)Reads all bytes from an input stream into a byte array. | 
public static long copy(InputStream from, OutputStream to) throws IOException
from - the input stream to read fromto - the output stream to write toIOException - if an I/O error occurspublic static long copy(ReadableByteChannel from, WritableByteChannel to) throws IOException
from - the readable channel to read fromto - the writable channel to write toIOException - if an I/O error occurspublic static byte[] toByteArray(InputStream in) throws IOException
in - the input stream to read fromIOException - if an I/O error occurspublic static long exhaust(InputStream in) throws IOException
InputStream until the end of the stream is
 reached. Returns the total number of bytes read. Does not close the stream.IOExceptionpublic static ByteArrayDataInput newDataInput(byte[] bytes)
ByteArrayDataInput instance to read from the bytes array from the
 beginning.public static ByteArrayDataInput newDataInput(byte[] bytes, int start)
ByteArrayDataInput instance to read from the bytes array,
 starting at the given position.IndexOutOfBoundsException - if start is negative or greater than the length of
     the arraypublic static ByteArrayDataInput newDataInput(ByteArrayInputStream byteArrayInputStream)
ByteArrayDataInput instance to read from the given
 ByteArrayInputStream. The given input stream is not reset before being read from by the
 returned ByteArrayDataInput.public static ByteArrayDataOutput newDataOutput()
ByteArrayDataOutput instance with a default size.public static ByteArrayDataOutput newDataOutput(int size)
ByteArrayDataOutput instance sized to hold size bytes before
 resizing.IllegalArgumentException - if size is negativepublic static ByteArrayDataOutput newDataOutput(ByteArrayOutputStream byteArrayOutputSteam)
ByteArrayDataOutput instance which writes to the given
 ByteArrayOutputStream. The given output stream is not reset before being written to by
 the returned ByteArrayDataOutput and new data will be appended to any existing content.
 Note that if the given output stream was not empty or is modified after the
 ByteArrayDataOutput is created, the contract for
 ByteArrayDataOutput.toByteArray() will not be honored (the bytes returned in the byte
 array may not be exactly what was written via calls to ByteArrayDataOutput).
public static OutputStream nullOutputStream()
OutputStream that simply discards written bytes.public static InputStream limit(InputStream in, long limit)
InputStream, limiting the number of bytes which can be read.in - the input stream to be wrappedlimit - the maximum number of bytes to be readInputStreampublic static void readFully(InputStream in, byte[] b) throws IOException
DataInput.readFully(byte[]). Does not close the stream.in - the input stream to read from.b - the buffer into which the data is read.EOFException - if this stream reaches the end before reading all the bytes.IOException - if an I/O error occurs.public static void readFully(InputStream in, byte[] b, int off, int len) throws IOException
len bytes from the stream into the given array starting at
 off, with the same behavior as DataInput.readFully(byte[], int, int). Does not
 close the stream.in - the input stream to read from.b - the buffer into which the data is read.off - an int specifying the offset into the data.len - an int specifying the number of bytes to read.EOFException - if this stream reaches the end before reading all the bytes.IOException - if an I/O error occurs.public static void skipFully(InputStream in, long n) throws IOException
n bytes of data from the input stream. This method will block until the full
 amount has been skipped. Does not close the stream.in - the input stream to read fromn - the number of bytes to skipEOFException - if this stream reaches the end before skipping all the bytesIOException - if an I/O error occurs, or the stream does not support skippingpublic static <T> T readBytes(InputStream input, ByteProcessor<T> processor) throws IOException
input - the input stream to processprocessor - the object to which to pass the bytes of the streamIOException - if an I/O error occurspublic static int read(InputStream in, byte[] b, int off, int len) throws IOException
b. This
 method blocks until len bytes of input data have been read into the array, or end of
 file is detected. The number of bytes read is returned, possibly zero. Does not close the
 stream.
 A caller can detect EOF if the number of bytes read is less than len. All subsequent
 calls on the same stream will return zero.
 
If b is null, a NullPointerException is thrown. If off is negative,
 or len is negative, or off+len is greater than the length of the array
 b, then an IndexOutOfBoundsException is thrown. If len is zero, then no
 bytes are read. Otherwise, the first byte read is stored into element b[off], the next
 one into b[off+1], and so on. The number of bytes read is, at most, equal to
 len.
in - the input stream to read fromb - the buffer into which the data is readoff - an int specifying the offset into the datalen - an int specifying the number of bytes to readIOException - if an I/O error occursCopyright © 2010–2017. All rights reserved.