PipedWriter (Java SE 21 & JDK 21)
- All Implemented Interfaces:
Closeable,Flushable,Appendable,AutoCloseable
public class PipedWriter extends Writer
Piped character-output streams.
- Since:
- 1.1
-
Field Summary
-
Constructor Summary
Constructors
Creates a piped writer that is not yet connected to a piped reader.
Creates a piped writer connected to the specified piped reader.
-
Method Summary
voidclose()Closes this piped output stream and releases any system resources associated with this stream.
voidConnects this piped writer to a receiver.
voidflush()Flushes this output stream and forces any buffered output characters to be written out.
voidwrite(char[] cbuf, int off, int len) Writes
lencharacters from the specified character array starting at offsetoffto this piped output stream.voidwrite(int c) Writes the specified
charto the piped output stream.
-
Constructor Details
-
PipedWriter
Creates a piped writer connected to the specified piped reader. Data characters written to this stream will then be available as input from
snk.- Parameters:
snk- The piped reader to connect to.- Throws:
IOException- if an I/O error occurs.
-
PipedWriter
public PipedWriter()
Creates a piped writer that is not yet connected to a piped reader. It must be connected to a piped reader, either by the receiver or the sender, before being used.
-
-
Method Details
-
connect
Connects this piped writer to a receiver. If this object is already connected to some other piped reader, an
IOExceptionis thrown.If
snkis an unconnected piped reader andsrcis an unconnected piped writer, they may be connected by either the call:or the call:
The two calls have the same effect.
- Parameters:
snk- the piped reader to connect to.- Throws:
IOException- if an I/O error occurs.
-
write
Writes the specified
charto the piped output stream. If a thread was reading data characters from the connected piped input stream, but the thread is no longer alive, then anIOExceptionis thrown.Implements the
writemethod ofWriter.- Overrides:
writein classWriter- Parameters:
c- thecharto be written.- Throws:
IOException- if the pipe isbroken,unconnected, closed or an I/O error occurs.
-
write
public void write
(char[] cbuf, int off, int len) throws IOException Writes
lencharacters from the specified character array starting at offsetoffto this piped output stream. This method blocks until all the characters are written to the output stream. If a thread was reading data characters from the connected piped input stream, but the thread is no longer alive, then anIOExceptionis thrown.- Specified by:
writein classWriter- Parameters:
cbuf- the data.off- the start offset in the data.len- the number of characters to write.- Throws:
IndexOutOfBoundsException- Ifoffis negative, orlenis negative, oroff + lenis negative or greater than the length of the given arrayIOException- if the pipe isbroken,unconnected, closed or an I/O error occurs.
-
flush
Flushes this output stream and forces any buffered output characters to be written out. This will notify any readers that characters are waiting in the pipe.
- Specified by:
flushin interfaceFlushable- Specified by:
flushin classWriter- Throws:
IOException- if the pipe is closed, or an I/O error occurs.
-
close
Closes this piped output stream and releases any system resources associated with this stream. This stream may no longer be used for writing characters.
- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Specified by:
closein classWriter- Throws:
IOException- if an I/O error occurs.
-