Труби в IO забезпечує зв'язок між двома потоками, що працюють у JVM одночасно. Отже, канали використовуються як джерело, так і призначення.
- PipedInputStream також передається за допомогою PipedOutputStream. Таким чином, дані можуть бути записані за допомогою PipedOutputStream і можуть бути записані за допомогою PipedInputStream. Але використання обох потоків одночасно створить взаємоблокування для потоків.
- Канал вважається зламаним, якщо потік, який надавав байти даних підключеному конвеєрному вихідному потоку, більше не працює.
Декларація: public class PipedInputStream extends InputStream
Конструктор: | PipedInputStream() : | створює PipedInputStream, який не підключений.
| PipedInputStream(int pSize) : | створює PipedInputStream, який не пов’язаний із вказаним розміром каналу.
| PipedInputStream(PipedOutputStream outStream) : | створює PipedInputStream, який підключається до PipedOutputStream - 'outStream'.
| PipedInputStream(PipedOutputStream outStream int pSize) : | створює конвеєрний вхідний потік, який підключається до конвеєрного вихідного потоку з указаним розміром труби. Методи: | int read(): | Reads the next byte of data from this piped input stream.The value byte is returned as an int in the range 0 to 255. This method blocks until input data is available the end of the stream is detected or an exception is thrown. Java // Java program illustrating the working of read() method import java.io.* ; public class NewClass { public static void main ( String [] args ) throws IOException { PipedInputStream geek_input = new PipedInputStream (); PipedOutputStream geek_output = new PipedOutputStream (); try { // Use of connect() : connecting geek_input with geek_output geek_input . connect ( geek_output ); // Use of read() method : geek_output . write ( 71 ); System . out . println ( 'using read() : ' + ( char ) geek_input . read ()); geek_output . write ( 69 ); System . out . println ( 'using read() : ' + ( char ) geek_input . read ()); geek_output . write ( 75 ); System . out . println ( 'using read() : ' + ( char ) geek_input . read ()); } catch ( IOException except ) { except . printStackTrace (); } } } Вихід: using read() : G using read() : E using read() : K
| read(byte[] buffer int offset int maxlen) : | java.io.PipedInputStream.read(byte[] buffer int offset int maxlen) зчитує до maxlen байтів даних із конвеєрного вхідного потоку в масив буферів. Метод блокується, якщо досягнуто кінця потоку або виникне виняткова ситуація. Синтаксис: public int read(byte[] buffer int offset int maxlen) Parameters : buffer : the destination buffer into which the data is to be read offset : starting in the destination array - 'buffer'. maxlen : maximum length of array to be read Return : next 'maxlen' bytes of the data as an integer value return -1 is end of stream is reached Exception : -> IOException : if in case IO error occurs. -> NullPointerException : if buffer is null. -> IndexOutOfBoundsException : if offset is -ve or maxlen is -ve or maxlen > buffer.length - offset.
| отримати (цілий байт): | java.io.PipedInputStream.receive(int byte) отримує байт даних. Якщо введення недоступне, метод блокується. Синтаксис: protected void receive(int byte) Parameters : byte : the bytes of the data received Return : void Exception : -> IOException : if in case IO error occurs or pipe is broken.
| close() : | java.io.PipedInputStream.close() закриває конвеєрний вхідний потік і звільняє виділені ресурси. Синтаксис: public void close() Parameters : -------------- Return : void Exception : -> IOException : if in case IO error occurs.
| підключення (джерело PipedOutputStream): | java.io.PipedInputStream.connect(джерело PipedOutputStream) з’єднує конвеєрний вхідний потік із «джерелом» конвеєрного вихідного потоку, і у випадку, якщо «джерело» є каналами з іншим потоком, створюється виняткова ситуація введення-виведення Синтаксис: public void connect(PipedOutputStream source) Parameters : source : the Piped Output Stream to be connected to Return : void Exception : -> IOException : if in case IO error occurs.
| наявний(): | java.io.PipedInputStream.available() повертає немає. байтів, які можна прочитати з вхідного потоку без фактичного блокування. Синтаксис: public int available() Parameters : ------------- Return : no. of bytes that can be read from Input Stream without actually being blocked. 0 if the stream is already closed but by invoking close() method Exception : -> IOException : if in case IO error occurs.
Програма Java, що пояснює роботу методів класу PipedInputStream: Java // Java program illustrating the working of PipedInputStream // connect() read(byte[] buffer int offset int maxlen) // close() available() import java.io.* ; public class NewClass { public static void main ( String [] args ) throws IOException { PipedInputStream geek_input = new PipedInputStream (); PipedOutputStream geek_output = new PipedOutputStream (); try { // Use of connect() : connecting geek_input with geek_output geek_input . connect ( geek_output ); geek_output . write ( 71 ); geek_output . write ( 69 ); geek_output . write ( 69 ); geek_output . write ( 75 ); geek_output . write ( 83 ); // Use of available() : System . out . println ( 'Use of available() : ' + geek_input . available ()); // Use of read(byte[] buffer int offset int maxlen) : byte [] buffer = new byte [ 5 ] ; // destination 'buffer' geek_input . read ( buffer 0 5 ); String str = new String ( buffer ); System . out . println ( 'Using read(buffer offset maxlen) : ' + str ); // USe of close() method : System . out . println ( 'Closing the stream' ); geek_input . close (); } catch ( IOException except ) { except . printStackTrace (); } } } Вихід: Use of available() : 5 Using read(buffer offset maxlen) : GEEKS Closing the stream
Next Article: Клас Java.io.PipedOutputStream у Java Створіть вікторину