Java NIO系列教程(11):Pipe,niopipe
分享于 点击 21700 次 点评:2
Java NIO系列教程(11):Pipe,niopipe
Java NIO 管道是2个线程之间的单向数据连接。Pipe
有一个source通道和一个sink通道。数据会被写到sink通道,从source通道读取。
这里是Pipe原理的图示:
创建管道
通过Pipe.open()
方法打开管道。例如:
Pipe pipe = Pipe.open();
向管道写数据
要向管道写数据,需要访问sink通道。像这样:
Pipe.SinkChannel sinkChannel = pipe.sink();
通过调用SinkChannel的write()
方法,将数据写入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); }
从管道读取数据
从读取管道的数据,需要访问source通道,像这样:
Pipe.SourceChannel sourceChannel = pipe.source();
调用source通道的read()
方法来读取数据,像这样:
ByteBuffer buf = ByteBuffer.allocate(48); int bytesRead = sourceChannel.read(buf);
read()
方法返回的int值会告诉我们多少字节被读进了缓冲区。
本系列:
- Java NIO系列教程(1):Java NIO 概述
- Java NIO系列教程(2):Channel
- Java NIO系列教程(3):Buffer
- Java NIO系列教程(4):Scatter/Gather
- Java NIO系列教程(5):通道之间的数据传输
- Java NIO系列教程(6):Selector
- Java NIO系列教程(7):FileChannel
- Java NIO系列教程(8):SocketChannel
- Java NIO系列教程(9):ServerSocketChannel
- Java NIO系列教程(10):Java NIO DatagramChannel
- Java NIO系列教程(11):Pipe
用户点评