 
 - 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 - PipedInputStream class
Introduction
The Java PipedInputStream class is a piped input stream that can be connected to a piped output stream, the piped input stream then provides whatever data bytes are written to the piped output stream.Following are the important points about PipedInputStream −
- The piped input stream contains a buffer, decoupling read operations from write operations, within limits. 
- Attempting to use both objects from a single thread is not recommended, as it may deadlock the thread. 
- A pipe is said to be broken if a thread that was providing data bytes to the connected piped output stream is no longer alive. 
Class declaration
Following is the declaration for Java.io.PipedInputStream class −
public class PipedInputStream extends InputStream
Field
Following are the fields for Java.io.PipedInputStream class −
- protected byte[] buffer − This is the circular buffer into which incoming data is placed. 
- protected int in − This is the index of the position in the circular buffer at which the next byte of data will be stored when received from the connected piped output stream. 
- protected int out − This is the index of the position in the circular buffer at which the next byte of data will be read by this piped input stream. 
- protected static int PIPE_SIZE − This is the default size of the pipe's circular input buffer. 
Class constructors
| Sr.No. | Constructor & Description | 
|---|---|
| 1 | PipedInputStream() This creates a PipedInputStream so that it is not yet connected. | 
| 2 | PipedInputStream(int pipeSize) This creates a PipedInputStream so that it is not yet connected and uses the specified pipe size for the pipe's buffer. | 
| 3 | PipedInputStream(PipedOutputStream src) This creates a PipedInputStream so that it is connected to the piped output stream src. | 
| 4 | PipedInputStream(PipedOutputStream src, int pipeSize) This creates a PipedInputStream so that it is connected to the piped output stream src and uses the specified pipe size for the pipe's buffer. | 
Class methods
| Sr.No. | Method & Description | 
|---|---|
| 1 | int available() This method returns the number of bytes that can be read from this input stream without blocking. | 
| 2 | void close() This method closes this piped input stream and releases any system resources associated with the stream. | 
| 3 | void connect(PipedOutputStream src) This method causes this piped input stream to be connected to the piped output stream src. | 
| 4 | int read() This method reads the next byte of data from this piped input stream. | 
| 5 | int read(byte[] b, int off, int len) This method reads up to len bytes of data from this piped input stream into an array of bytes. | 
| 6 | protected void receive(int b) This method receives a byte of data. | 
Methods inherited
This class inherits methods from the following classes −
- Java.io.InputStream
- Java.io.Object
Example - Checking available bytes after writing data to a pipe
The following example shows the usage of PipedInputStream available() method.
PipedInputStreamDemo.java
 package com.tutorialspoint; import java.io.PipedInputStream; import java.io.PipedOutputStream; import java.io.IOException; public class PipedInputStreamDemo { public static void main(String[] args) { try { PipedOutputStream pos = new PipedOutputStream(); PipedInputStream pis = new PipedInputStream(pos); pos.write("Hello".getBytes()); // Check how many bytes are available to read int availableBytes = pis.available(); System.out.println("Available bytes: " + availableBytes); // Should print 5 // Read the data byte[] buffer = new byte[availableBytes]; pis.read(buffer); System.out.println("Data read: " + new String(buffer)); pos.close(); pis.close(); } catch (IOException e) { e.printStackTrace(); } } }  Output
Let us compile and run the above program, this will produce the following result−
Available bytes: 5 Data read: Hello
Explanation
- available() returns the number of bytes that can be read without blocking. 
- After writing "Hello" (5 bytes), available() returns 5. 
- This is useful when you want to know how much data is ready for immediate reading. 
Example - Closing PipedInputStream after reading data
The following example shows the usage of PipedInputStream close() method.
PipedInputStreamDemo.java
 package com.tutorialspoint; import java.io.PipedInputStream; import java.io.PipedOutputStream; import java.io.IOException; public class PipedInputStreamDemo { public static void main(String[] args) { try { // Create and connect piped streams PipedOutputStream pos = new PipedOutputStream(); PipedInputStream pis = new PipedInputStream(pos); // Write some data pos.write("Hello, Pipe!".getBytes()); // Read data from input stream byte[] buffer = new byte[pis.available()]; pis.read(buffer); System.out.println("Read: " + new String(buffer)); // Close the input stream pis.close(); pos.close(); System.out.println("PipedInputStream closed successfully."); } catch (IOException e) { e.printStackTrace(); } } }  Output
Let us compile and run the above program, this will produce the following result−
Read: Hello, Pipe! PipedInputStream closed successfully.
Explanation
- close() is used to release system resources associated with the input stream. 
- After reading the data, the input stream is closed to prevent memory leaks or resource exhaustion. 
- Always closing both ends of a pipe (PipedInputStream and PipedOutputStream) is best practice. 
Example - Connecting PipedInputStream and PipedOutputStream manually
The following example shows the usage of PipedInputStream connect(PipedOutputStream src) method.
PipedInputStreamDemo.java
 package com.tutorialspoint; import java.io.PipedInputStream; import java.io.PipedOutputStream; import java.io.IOException; public class PipedInputStreamDemo { public static void main(String[] args) { try { PipedInputStream input = new PipedInputStream(); PipedOutputStream output = new PipedOutputStream(); // Manually connect input to output input.connect(output); // Write data from output output.write("Hello via pipe".getBytes()); // Read the data using input byte[] buffer = new byte[input.available()]; input.read(buffer); System.out.println("Received: " + new String(buffer)); input.close(); output.close(); } catch (IOException e) { e.printStackTrace(); } } }  Output
Let us compile and run the above program, this will produce the following result−
Received: Hello via pipe
Explanation
- connect(PipedOutputStream pos) links the PipedInputStream to the specified PipedOutputStream. 
- This is an alternative to the constructor-based connection (new PipedInputStream(output)). 
- After connecting, data written to the output stream can be read from the input stream.