
- Java.io - Home
- Java.io - BufferedInputStream
- Java.io - BufferedOutputStream
- Java.io - BufferedReader
- Java.io - BufferedWriter
- Java.io - ByteArrayInputStream
- Java.io - ByteArrayOutputStream
- Java.io - CharArrayReader
- Java.io - CharArrayWriter
- Java.io - Console
- Java.io - DataInputStream
- Java.io - DataOutputStream
- Java.io - File
- Java.io - FileDescriptor
- Java.io - FileInputStream
- Java.io - FileOutputStream
- Java.io - FilePermission
- Java.io - FileReader
- Java.io - FileWriter
- Java.io - FilterInputStream
- Java.io - FilterOutputStream
- Java.io - FilterReader
- Java.io - FilterWriter
- Java.io - InputStream
- Java.io - InputStreamReader
- Java.io - LineNumberInputStream
- Java.io - LineNumberReader
- Java.io - ObjectInputStream
- Java.io - ObjectInputStream.GetField
- Java.io - ObjectOutputStream
- io - ObjectOutputStream.PutField
- Java.io - ObjectStreamClass
- Java.io - ObjectStreamField
- Java.io - OutputStream
- Java.io - OutputStreamWriter
- Java.io - PipedInputStream
- Java.io - PipedOutputStream
- Java.io - PipedReader
- Java.io - PipedWriter
- Java.io - PrintStream
- Java.io - PrintWriter
- Java.io - PushbackInputStream
- Java.io - PushbackReader
- Java.io - RandomAccessFile
- Java.io - Reader
- Java.io - SequenceInputStream
- Java.io - SerializablePermission
- Java.io - StreamTokenizer
- Java.io - StringBufferInputStream
- Java.io - StringReader
- Java.io - StringWriter
- Java.io - Writer
- Java.io package Useful Resources
- Java.io - Discussion
Java - PushbackInputStream read(byte[] b,int off,int len) method
Description
The Java PushbackInputStream read(byte[] b,int off,int len) method reads up to len bytes of data from this input stream into an array of bytes. This method first reads any pushed-back bytes; after that, if fewer than len bytes have been read then it reads from the underlying input stream. If len is not zero, the method blocks until at least 1 byte of input is available; otherwise, no bytes are read and 0 is returned.
read(byte[] b,int off,int len) method −
Reads up to len bytes of data from the input stream into an array b, starting at offset off.
Returns the number of bytes read, or -1 if the end of the stream is reached.
Commonly used when you want to fill part of a buffer, not necessarily from the start.
Declaration
Following is the declaration for java.io.PushbackInputStream.read(byte[] b,int off,int len) method.
public int read(byte[] b,int off,int len)
Parameters
b − The buffer into which the data is read.
off − The start offset in the destination array b.
len − The maximum number of bytes read.
Return Value
This method returns the total number of bytes read into the buffer, or -1 if there is no more data because the end of the stream has been reached.
Exception
NullPointerException − If b is null.
IndexOutOfBoundsException − If off is negative, len is negative, or len is greater than b.length - off.
IOException − If this input stream has been closed by invoking its close() method, or an I/O error occurs.
Example - Usage of PushbackInputStream read(byte[] b,int off,int len) method
The following example shows the usage of PushbackInputStream read(byte[] b,int off,int len) method.
PushbackInputStreamDemo.java
package com.tutorialspoint; import java.io.*; public class PushbackInputStreamDemo { public static void main(String[] args) { // declare a buffer and initialize its size: byte[] arrByte = new byte[1024]; // create an array for our message byte[] byteArray = new byte[]{'H', 'e', 'l', 'l', 'o'}; // create object of PushbackInputStream class for specified stream InputStream is = new ByteArrayInputStream(byteArray); PushbackInputStream pis = new PushbackInputStream(is); try { // read a char into our array pis.read(arrByte, 0, 3); // print arrByte for (int i = 0; i < 3; i++) { System.out.print((char) arrByte[i]); } } catch (Exception ex) { ex.printStackTrace(); } } }
Output
Let us compile and run the above program, this will produce the following result −
Hel
Example - Read into middle of a buffer
The following example shows the usage of PushbackInputStream markSupported() method.
PushbackInputStreamDemo.java
package com.tutorialspoint; import java.io.ByteArrayInputStream; import java.io.PushbackInputStream; import java.io.IOException; public class PushbackInputStreamDemo { public static void main(String[] args) throws IOException { byte[] data = "HELLO".getBytes(); // Source stream try (PushbackInputStream pbis = new PushbackInputStream(new ByteArrayInputStream(data))) { byte[] buffer = new byte[10]; // Larger buffer than needed // Read 3 bytes into buffer starting at offset 2 int bytesRead = pbis.read(buffer, 2, 3); System.out.println("Bytes read: " + bytesRead); // Output: 3 System.out.println("Buffer content: " + new String(buffer)); // Output shows nulls + 'HEL' } } }
Output
Let us compile and run the above program, this will produce the following result−
Bytes read: 3 Buffer content: HEL
Explanation
Only 3 bytes are read (H, E, L).
They're placed in buffer[2], buffer[3], and buffer[4].
The rest of the buffer contains default zero values.
Example - Combine unread and read with offset
The following example shows the usage of PushbackInputStream read(byte[] b,int off,int len) method.
PushbackInputStreamDemo.java
package com.tutorialspoint; import java.io.ByteArrayInputStream; import java.io.PushbackInputStream; import java.io.IOException; public class PushbackInputStreamDemo { public static void main(String[] args) throws IOException { byte[] data = "JAVAIO".getBytes(); try (PushbackInputStream pbis = new PushbackInputStream(new ByteArrayInputStream(data), 10)) { byte[] buffer = new byte[6]; // Read first 4 bytes pbis.read(buffer, 0, 4); // J A V A System.out.println("First read: " + new String(buffer, 0, 4)); // Output: JAVA // Unread last 2 bytes (V and A) pbis.unread(buffer, 2, 2); // Read next 3 bytes into buffer starting at index 3 pbis.read(buffer, 3, 3); // V A I System.out.println("Final buffer: " + new String(buffer)); // Output: JAVAI_ } } }
Output
Let us compile and run the above program, this will produce the following result−
First read: JAVA Final buffer: JAVVAI
Explanation
First read: JAVA.
Unread 'V' and 'A'.
Read 3 more bytes into the middle of the buffer (buffer[3], buffer[4], buffer[5]): VAI.