參考:http://ifeve.com/pipe/
原文地址
目錄
- Java NIO教程
- Java NIO 教程(一) 概述
- Java NIO 教程(二) Channel
- Java NIO 教程(三) Buffer
- Java NIO 教程(四) Scatter/Gather
- Java NIO 教程(五) 通道之間的數(shù)據(jù)傳輸
- Java NIO 教程(六) Selector
- Java NIO 教程(七) FileChannel
- Java NIO 教程(八) SocketChannel
- Java NIO 教程(九) ServerSocketChannel
- Java NIO 教程(十) 非阻塞式服務器
- Java NIO 教程(十一) Java NIO DatagramChannel
- Java NIO 教程(十二) Pipe
- Java NIO 教程(十三) Java NIO vs. IO
- Java NIO 教程(十四) Java NIO Path
- Java NIO 教程(十五) Java NIO Files
- Java NIO 教程(十六) Java NIO AsynchronousFileChannel
Java NIO Pipe
是2個線程之間的單向數(shù)據(jù)連接耻姥。Pipe有一個source
通道和一個sink
通道。數(shù)據(jù)會被寫到sink
通道侣诵,從source
通道讀取。
這里是Pipe原理的圖示:
Pipe原理
創(chuàng)建管道
通過Pipe.open()
方法打開管道柴钻。例如:
Pipe pipe = Pipe.open();
向管道寫數(shù)據(jù)
要向管道寫數(shù)據(jù),需要訪問sink通道垢粮。像這樣:
Pipe.SinkChannel sinkChannel = pipe.sink();
通過調用SinkChannel
的write()
方法贴届,將數(shù)據(jù)寫入SinkChannel
,像這樣:
String newData = "New String to write to file..." + System.currentTimeMillis();
ByteBuffer buf = ByteBuffer.allocate(48);
buf.clear();
buf.put(newData.getBytes());
buf.flip();
while(buf.hasRemaining()) {
sinkChannel.write(buf);
}
從管道讀取數(shù)據(jù)
從讀取管道的數(shù)據(jù),需要訪問source
通道蜡吧,像這樣:
Pipe.SourceChannel sourceChannel = pipe.source();
調用source
通道的read()
方法來讀取數(shù)據(jù)毫蚓,像這樣:
ByteBuffer buf = ByteBuffer.allocate(48);
int bytesRead = inChannel.read(buf);
read()方法返回的int值會告訴我們多少字節(jié)被讀進了緩沖區(qū)。