Java NIO 管道是2个线程之间的单向数据连接。Pipe有一个source通道和一个sink通道。数据会被写到sink通道,从source通道读取。在Java NIO中,包java.nio.channel.pipe用于按顺序读取和写入数据。管道用于确保数据必须以写入管道的相同顺序读取。
原理图
创建管道
使用Pipe.open()方法打开通道,如
Pipe pipe = Pipe.open();
向管道中写入数据
要向管道中写入数据,需要访问sink通道。如:
Pipe.SinkChannel sinkChannel = pipe.sink();
然后调用SinkChannel的write()方法,将数据写入到SinkChannel,如
String data = "write String to SinkChannel..." + System.currentTimeMillis();
ByteBuffer buffer = ByteBuffer.allocate(48);
buffer.clear();
buffer.put(data.getBytes());
buffer.flip();
while (buffer.hasRemaining()) {
sinkChannel.write(buffer); // 将Buffer中的数据写入到SinkChannel中
}
从管道中读取数据
读取管道中的数据,需要访问source通道。如
Pipe.SourceChannel sourceChannel = pipe.source();
然后调用source通道的read()方法来读取数据,如
ByteBuffer buffer = ByteBuffer.allocate(48);
int readBytes = sourceChannel.read(buffer);
read()方法的返回值表示读取了多少个字节进缓存区Buffer。