Java NIO 管道是2个线程之间的单向数据连接。Pipe有一个source通道和一个sink通道。数据会被写到sink通道,从source通道读取。
这里是Pipe原理的图示:
通过Pipe.open()方法打开管道。例如:
1Pipe pipe = Pipe.open();要向管道写数据,需要访问sink通道。像这样:
1Pipe.SinkChannel sinkChannel = pipe.sink();通过调用SinkChannel的write()方法,将数据写入SinkChannel,像这样:
01 String newData = "New String to write to file..." + System.currentTimeMillis(); 02 ByteBuffer buf = ByteBuffer.allocate(48); 03buf.clear(); 04buf.put(newData.getBytes()); 05 06buf.flip(); 07 08 while(buf.hasRemaining()) { 09 sinkChannel.write(buf); 10}从读取管道的数据,需要访问source通道,像这样:
1Pipe.SourceChannel sourceChannel = pipe.source();调用source通道的read()方法来读取数据,像这样:
查看源代码 打印 帮助 1 ByteBuffer buf = ByteBuffer.allocate(48); 2 3 int bytesRead = sourceChannel.read(buf);read()方法返回的int值会告诉我们多少字节被读进了缓冲区。
文章转自 并发编程网-ifeve.com
相关资源:敏捷开发V1.0.pptx